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ثقنية الحاسب الآلي ۱٦۱‏ حاب مقدمة 
الرمجيات مقدمة قواعد بيانات أوراكل 


مقدمة 


ألحمد وخ والصلاة والسلام على من لا لبي بعده› محمد علي اه و صحبه› ويعلد : 


تسعى المؤسسة العامة للتعليم الفني والتدريب المهني لتآهيل الكوادر الوطنية المدرية القادرة على 
شغل الوظائف التقنية والفنية والمهنية المتوفرة 4 سوق العمل» ويآتي هذا الاهتمام نتيجة للتوجهات 
السديدة من لدن قادة هذا الوطن التي تصب ب4 مجملها نحو إيجاد وطن متڪامل يعتمد اتا على موارده 
وعلی قوة شبابه المسلح بالعلم والإيمان من آ جل الاستمرار ا 4 دفع عجلة التقدم التنموي؛ لتصل بعون 
الله تعالى لمصاف الدول المتقدمة ا 


وقد خطت الإدارة العامة لتصميم ES‏ خطوة إيجابية تتفق مع التجارب الدولية المتقدمة 
ج بناء البرامج التدريبية» وفق أساليب علمية حديثة تحاكي متطلبات سوق العمل بكافة تخصصاته 
لتلبي متطلباته › وقد تمثلت هذه الخطوة 2 مشروع إعداد المعايير المهنية الوطنية الذي يمثل الركيزة 
الأساسية 2 بناء البرامج التدريبية› GE‏ على تشكيل لجان تخصصية تمثل سوق 


CS E E 
مر متطلبات سوق العمل»› > لتخرج هذه اللجان 2 النهابة بنظرة متكاملة لبرنامج تدريبي آڪثر‎ 
التصاقا بسوق العمل» وآأكثر واقعية 2 تحقيق متطاباته اشاش‎ 


وتتناول هده الحقيية التدريبية مقدذفة فواعد بیانات آوراڪل 1 كرتن قسم البرمجيات 1 


والادارة العامة لتصميم وتطوير المناهج وهی تصع بىن يديك هده الحقيية التدريبية تاآمل من اله عر 
ا هف س ا و ا ف و د 
ويالاستعانة بالتطبيقات والآشكال ال تدعم عملية اڪتساب هده المهارات. 


والله نسأل أن يوفق القائمين على إعدادها والمستفيدين منها لما يحبه ويرضاه؛ إنه سميع مجيب 
الغا 


الإدارة العامة لتصميم وتطوير المناهج 


تقنية الحاسب الآلي ۱ حاب تمهید 
الارمجيات مقدمة قواعد بيانات أوراكل 


مید 
أهمية قواعد البيانات: 


e EG NO O 
معلومة معينة آو استنتاج واستتباط فكرة ما وهي ضرورية جدا لصاحب القرار ج آي مجال‎ 
ENT TE O TPS IT E EEE 
2 الموجودين ب2 مدينة معينة 2 المملكة العربية السعودية وذلك لتحديد عدد الأطباء المفروض توفيرهم‎ 
كل مدينة مثلا » فذلك يتطلب أن يكون هناك بيانات دقيقة حول المرضى والسكان ب ڪل مدينة‎ 
a O O O e O N 
الأطباء وباقي الاحتياجات الضرورية » وبالمثل لو احتاجت الوزارة اتخاذ قرار ما حول محارية مرض‎ 
معين فلابد آن يتوفر لديها معلومات حول المدن التي يتنشر فيها المرض و نسبة انتشاره وعليه يتم اتخاذ‎ 
القرار المناسب لمحارية هذا المرض قبل انتشاره . فلو فرضنا أن هذه البيانات غير متوفرة أو أنها متوفرة‎ 
بشكل غير منظم وغير دقيق فإن عملية اتخاذ القرار سوف تتآخر بشكل كبير ومن الممكن أن يتخذ‎ 
قرار غير مناسب مما يؤثر على عملية تسييروتشغيل آمور المواطنين وما يترتب عليه من أضرار . ومن‎ 
هذا نستنتج آن عملية جمع البيانات الدقيقة والتعامل معها بشكل صحيح من آهم العمليات التي تؤثر‎ 
. بشكل مباشر 4 الحياة اليومية وبخاصة ونحن 4 عصر المعلومات‎ 

يك الزات رة اساات اود اناده رى إل مارات صح رالانات يرالد 
تؤدي إلى معلومات غير صحيحة وعليه فلابد من دراسة وتحليل البيانات واكتشاف آنظمة لتسهيل 
هوام رضمان سلا الانات ورا لضان الا اة التصري فن ااارعات , وضم الكل 
التالي العلافة بين البيانات والمعلومات . 


حفظ ومعالجة البيانات 


Informat1ons 
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CRIPT larguage="davaSeript"> 
nt iH animateAnChor ld { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 
الجدارة : 


معرفة ما هي قواعد البيانات ومراحل تطورها وأنواعها . 


الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على : 
| - فهم فواعد البيانات . 
۲ - مراحل تطور فقواعدالبيانات . 
۲ - آنواع آنظمة إدارة قواعد البيانات . 
¿٤‏ -قواعد البيانات العلائقية . 
ه -لغة التعامل مع قواعد البيانات ( لغة الاستفسارات ]8 ). 
٦‏ -التعرف على بيئة ۴0S‏ ا84 . 


مستوى الأداء المطلوب : 
أن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١١‏ . 


الوفت المتوفع للتدريب : ساعتان 
الوسائل المساعدة : 


فلم . 
8 ,دفر 


متطلبات الجدارة : 
إلمام متوسط باللغة الإنجليزية › التعامل الجيد مع أساسيات الحاسب الآلي . 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


رقم المتدرب الأكاديمي: ٠٠٠١‏ - 


I- YY 
(Record) Jz حقل (1۵ع۴1)‎ 
اسم المندرب عبدالعزيز محمد احمد‎ 


القسم التايع له : الحاسب الآلي 


قاعدة بيانات طلاب 


Database Concepts تlذllا مفھوم فواعد‎ 


نفرض آننا نريد جمع البيانات عن المتدربين 4 كلية معينة »فإنه من المعروف آن لكل متدرب 
E E I e O O DTT‏ 
جمعنا بيانات كل متدرب 4 بطافقة وسميناها ( سجل المتدرب [ ۸۴٣۳0۸‏ ) ول بيان من بيانات 
E CD EE a a‏ وف ل عل ماوت ةرمن غ 
جمع هذه السجلات مع بعضها نحصل على قاعدة بیانات للمتدربین تسمی 0۸1۸8۸85۴٤‏ . كما 2 
اش کل 
رقم (۱). 


مراحل تطور قواعد البيانات : 


oe N Ca EEE 

a ET Te Gn 7‏ 1 و : يمر e Se‏ 
علماء فواعد البيانات فقد تم وصع نظریات وآساليب كڪثرة للتعامل مع البيانات ومنها علئ سبیل 
المثال الات 


تقنية الحاسب | ١‏ حاب الفصل الأول 


الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


3 
ت 


. Electronic Spread sheets ةuiورتکیلإ حفظ البیانات 2 بطاقات نشر‎ ١ 


تعتمد هذه الطريقة على حفظ البيانات داخل بطاقات إلكترونية يتم التعامل معها بشكل معين وتعتبر 


. Filling Cab1net حفظ البیانات ے2 ملفات تسمى مخازن معبًة‎ ١ 

NEE CS CE O SE 
. القديمة للتعامل مع فواعد البيانات‎ 

١‏ حفظ البيانات 24 قواعد بيانات Database‏ وتعتبر هذه الطريقة هي الآأحدث بالنسبة للطرق السابقة 
الذكر حيث تم عمل آنظمة للتعامل مع قواعد البيانات لتسهيل عملية تخزين البيانات 
واسترجاعها والتعديل فيها بسهولة ودقة (معالجتها) وتسمى هذه الآأنظمة أنظمة إدارة قواعد 
البيانات Database Mangement System (DBMS)‏ ومن هذه الأنظمة ماهو موضح الشكل 
رقم (۲) . 


Type of Database Management Systems ةlذlalلا أنواع أنظمة إدارة قواعد‎ 


طا 


Relational 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


سے 


أنواع أنظمة إدارة قواعد البيانات: 


نظام إدارة قواعدالبيانات الہرمية Hierarchical database Mangement system‏ 
هذا النظام یستخدم 2 الماضى وبخاصة مع آأجهزة الحاسب الكبيرة التي يطلق علیها 
Ma10 ۴2m‏ حیث ڪان هذا النظام يتناسب معها بشڪل جيد 


نظام إدارة قواعد البيانات الشبكية Network database Mangement system‏ 
صعوبات كثيرة ب2 عملية فهم وطبيعة التعامل مع البيانات كما ب2 النظام الهرمي . 


نظام إدارة قواعد البيانات العلائقية Relational database Mangement system‏ 
يعتبر هذا النظام هو النظام الذي تعتمد عليه غلب برامج قواعد البيانات مثل أوراكل لأنه من 
Eg Elle Eagle EAE SES KES‏ 
آدائه من حيث السرعة والدقة » ولآن هذا النظام يتمتع بالسرية والآمان لاحتوائه على نظام إعطاء 
الصلاحيات والحقوق لمستخدميه ولسهولته 2 الاستخدام والفهم وسهولة برمجة تطبيقاته . 


Emplovee Table Department Table 


__ 7782 | CLARK | MANAGER | _ 10 ®, 
__ 1566 | JONES | MANAGER | 20 


7369 SMITH CLERK 

7499 ALLEN | SALESMAN 
7521 | WARD | SALESMAN علاده‎ 
7698 | MARIN | SALESMAN Relig 
7654 SCOTT | ANALYST 


تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الأول 


الارمجيات مقدمة قواعد بيانات أوراكل مقدمة 
فواعد البيانات العلائقية Relational Databse‏ 


تعتمد قواعد البيانات العلائقية على جمع البيانات 2 جداول بسيطة ثنائية الأبعاد يسهل فهمها 
تتكون من صفوف وأعمدة » و كل عمود ( )€0110۳١‏ 2 الحداول عبارة عن حقل 
( ۴11۵ ) و كل صف ( ۸0W‏ ) من صفوف هذه الجداول عبارة عن سجل (0۲۵٥ء۸‏ ) . وتم ريط هذه 
الجداول مع بعضھا بروابط تسمی ( ١5١13110ء‏ ۸ ) ومن هنا جاءت تسميت قواعد البيانات 
العلائقية . 

فقواعد البيانات العلائقية هي مجموعة من الجداول التي لہا علاقة ما ببعضها . والشكل رقم )١(‏ 
يبين جدولين آحدهما يمثل بيانات الإدارات والآخر يمتثل بيانات الموظفين » كما يببن الشكل العلاقة 
بين الجدولين من خلال وجود العمود ( ٤P1 N0‏ 0 ) 2 كلا الجدولين . 


التعامل مع قواعد البيانات العلائفية Manipulate with relational database‏ 


قامت شركة آوراكل باعتماد لغفة تسمى لغة الاستفسارات Structured Query  ) S$SQL‏ 
86م ) للتعامل مع قواعد البيانات العلائقة وهي لغة سهلة تقوم بإنشاء الأشياء (كءء[ا0) 
A E Lae e a a NA ENE‏ 
ET E E O TOI EER E‏ 
COOL PE UST NN Sas, OLE EOL ON‏ 
NEE COD RIE OC NG‏ 
ك الآمر وجميع العمليات الآخرى » وسوف نقوم بشرح مفصل عن كل من لغة ]5)01 والمحرر 
SQ1* 68‏ فیما يلي : 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


لغ الاwتفluرlIت Structured Query Language (SQL)‏ 
ھی عة تستحدم لإصدار جميع الآوامر التى تتعلق بقاعدة البيانات وتنفسم هذه األغة 2 خمسة 
المختلفة من هده اللغة وو صف الأوامر لڪل قسم 


ال 
آمر استرجاع البيانات من جدول و ڪائن 


او آ ا INSERT‏ 
مر إضافة بیانات إلى جدول آو ڪاتن ات د (DML)‏ 


آمر التعدیل ے2 بیانات جدول آو ڪان Data Manıipulation UPDATE‏ 


E O e 
الغاء جزء آو بتر جزء من جدول و ڪائن‎ 

تثبيت البيانات بك الجدول 

إعطاء الصلاحيات للمستخدمين للدخول على البيانات (DCL)‏ 


کے آلا خا ت هن ا دن Data Control Language | REVOKE‏ 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


تعلیمات خبارات بحت احریر يلف 


SHLEPIuS =: RHFIlIFPFase HFH 1-6-B-BA ~~ PrFoduCcFIiOoONn on IY ++ aa cTy %4 1 + 


{CJ Copyright 13999 NONracle Corporation - ALL Fights rFeserued _ 


سے 


Oracle#i Personal Edition Release fRf_1-.6-B-B 


iTEh the Java option 
JISerFuFPrF RelFace HF 16GB. —~ Production 


I scott 
Itiger 


الشكل رقم )٤(‏ 


مجرر (بيئة ) أل S؟0ا۴‏ *اSQ.‏ 

الشكل رقم )٤(‏ يبين شاشة الدخول على محرر 841*118 حيث تقوم بكتابة اسم المستخدم 
وهو )5٤0011(‏ وكلمة المرور وهي )116٤R(‏ ثم الضغط على مفتاح (موافق) وذلك للدخول على 
الخرر لاي لا ر ا ا ار ن 00 عا وان واا و هه الور مكنا 
تتغير وذلك على حسب المستخدم هل له صلاحية الدخول آم لا »> فمن الممكن أن تدخل على المحرر باسم 
المستخدم ([S1۴؟S۲)‏ وكلمة المرور )M۷۸4AN۸6٤8(‏ و2 هذه الحالة تدخل عليه وكأنك ( مدير قاعدة 
البيانات ) »> ويتكون محرر 0S-اSQ[*۴‏ من قائمة تساعدك على تحرير الأمر والتعديل فيه وتنفيذه › 
ووجود الرمز( < 1ا50 ) وهذا يشير إلى آنك تستطيع كتابة آي آمر بعده » وهناك بعض الأوامر 
البسيطة التي تساعدك 4 كتابة وتعديل وتنفيذ الأمر ومنها على سبيل المثال . 


e SQL > EDIT 
وعند تنفيذ هذا الأمر‎ » 8Q1[*۴]0S يستخدم هذا الأمر لتعديل آخر أمر تم كتابته على محرر‎ 
ستظهر لك شاشة (المفكرة) ويهماآخر آمرتم كتابته حيث يمكن من خلال هده‎ 


الشاشة التعديل 2 الآأمر ثم حفظه وتنفيذه مرة آخری من خلال محرر SQL*PLUS‏ »> ويمڪن 
اختصار هذا الآمر فیکتب كالاتی : (٤غ‏ < SQ]‏ . 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


e SOL > RUN 
وگن كتاية‎ SQL*PLUS يستحدم هذا الأمر لإعادة تنفيد آخر آمر تم كڪتابته 2 محرر‎ 


هذا الأمر بالشكل التالي : ۸ <اS؟‏ . 


e SQL > SPOOL Filename 


يستخدم هذا الأمر عندما نريد حفظ كل ما تم عمله داخل محرر؟S‏ 501*۴10 2 ملف نصي 
بامتداد (081]) وذلك بغرض استرجاعها ومراجعتها » ومن الممكن أن نحصل على نسخة مطبوعة 
بواسنطة الأمر التالى : SQL > SPOOL OUT‏ 


e SQL > SAVE filename 
يستخدم هذا الآمر لحفظ الآوامر 2 ملف وذلك لاسترجاعها مرة آخرى وتتفيذها وهنا لابد من حفظ‎ 


الملف بامتداد ([54) وذلك لنتمكن من تشغيله مرة آخرى . فاذا أردنا حفظ أمر ما داخل ملف اسمه 
أ٩ك.‏ عا نكتب الأمر التالى : SQL > SAVE test.sql‏ 


e SQL > GET filename 


يستحدم هذا الآمر لاسترجاع الأوامر التي نم حفظها بواسطة الأمر السابق . وذلك لتفيذها مرة 
آخری . فإذا أردنا استرجاع الآوامر من الملف [5۲.54ع] نكتب الأآمر التالى : 1ء.†sئte SQL <> GET‏ . 


e SQL > START filename 


يستحدم هذا الآمر ك تنفيد الآوامر الموجودة 2 ملف تم حفظه بامتداد sql‏ « فاذا اردنا تنفيد 
لوار ا ا و و وک لایر الى 


SQL > START test.sql 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


سے 


e SQL > (w filename 
. هذا الآمر مثل الآمر السابق تماما‎ 


e SQL > LIST 


يستخدم هذا الآمر 2 استعراض سطور آخر آمر تم كتابته » ويمكن استعراض سطور معينة 
E a‏ 
SQL > L1 3‏ 


تقنية الحاسب الآلي ۱ حاب الفصل الأول 
الرمجيات مقدمة قواعد بيانات أوراكل مقدمة 


سے 


أسنلة الفصل الأول 
١‏ - ماذا تعن الكلمات llتlلıة (TABLE , ROW , COLUMN)‏ . 
٣‏ - لماذا يعتبر نظام إدارة قواعد البيانات العلائقة من آقوى أنظمة إدارة قواعد البيانات ؟ 
٤‏ - اذكر الفرق بين المحرر Sاا۴* SQ‏ و لغة آاSQ؟S 5Ş‏ 
aN OLE E‏ 


يعتب ر أمر الاستعلام S٤1[٤ ٣1‏ من أوامر محرر 501*۴18 ويستخدم لاسترجاع البيانات. ( ) 

) ( . تستخدم مجموعة أوامر ا۷( لعالجة بيانات الجداول‎ ١ 

١‏ يستخدم الأمر ا8۶00 <501 لحفظ الأوامر التي نكتبها 2 المحرر داخل ملف ليسهل 
مراجعتها . () 

يستخدم الأمر 4 2 1 لعرض السطور مبتدائ من السطر الثاني وحتى السطر الرابع ( ) 

) ( لتنفينذ عدة آوامر تم حفظها من قبل‎ 501< S14۴8" يستخدم الأمر‎ ١ 

يعتبرالآمر ١لاR‏ من آوامر لغة الاستفسارات اQ؟‏ ( ) 


مقدمة فواعد بيانات أوراكل 


Len (rsllsg) = 7 hek Project - frmBmi [Code] ۹‏ ا 
Screen, HousePointer f‏ 


| PEFivatEe Bub cmatalc £ | 

trmMD1.stsdtatusPar, Fi E ERE 
NEL 

If tPausêflagf The 


End Sub 


ا 


A | 


Hh E E Êêê Û + AEA e“‏ ج 


CRIPT languages" JavaStFipt"y 


iHSZLEion animateAnChor ll { 
WAE E]=eTERT,.SECE lermeEent ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


جملة ( SE ٤٣1‏ ) الأساسية 


الجدارة : 
معرفة جملة 1 9٤8€“‏ الآساسية وأجزاتها المختلفة وكيفية التعامل معها . 


الأهداف : 
ل کو ا او کا 
١‏ - فهم الصيغة العامة لجملة 9٤1٤٤1‏ . 
۲ - متطلبات وإرشادات كتابة جمل 1 SELEC‏ . 
٣‏ - استرجاع البيانات من الجداول بواسطة جملة 1 91٤€‏ . 
٤‏ - استرجاع الحقول باسماء مستعارة ( A]146€5‏ ) . 
ه - استخدام العمليات الحسابية وأولويات تتفيذها مع جملة 9٤1٤0٣1‏ . 
٦‏ - استخدام أداة الربط بين الحقول ( | | ( Concaten2t101‏ . 
۷ - استخدام عبارة 1 11N€‏ 015 لنع تكرار السجلات . 
۸ - إظهار البناء الداخلي للجداول باستخدام الأمر (٤8ئعل)‏ عط1إعdes‏ . 
٩‏ - التعامل مع القيمة NULL‏ . 


مستوى الأداء المطلوب : 

أن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 
الوفت المتوقع للقدريب : آربع ساعات 
الوسائل المساعدة : 


© فلم . 
۵ دفتر. 
متطلبات الجدارة : 


EE 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


الصيغة ( الشكل ) العامة لجملة ٤)٥1‏ اSE‏ . 


SELECT * or Columns [alias | 
FROM Table 


WHERE condition or conditions 
ORDER BY Column or Alias [ASC or DESC] 


تفسار الصيغة العامة : 


. تستخدم 2 بداية الأمر لاسترجاع البيانات من الجداول‎ SELECT 
. هذا الرمز يستخدم عند استرجاع جميع الحقول من الجدول‎ * 
. 65ئ0امعئلاىل أسم الحقل آو الحقول المراد استرجاعها من الجدول‎ 
. الاسماء المستعارة للحقول‎ 8 
. تستخدم للإعلان عن اسم الجدول‎ ۴۸0M 
. اسم الجدول المراد استرجاع البيانات منه‎ ۴6 
. تستخدم للإعلان عن الشرط أو الشروط‎ WHERE 
. الشرط آوالشروط اللازمة لحصر البيانات الآتية من الجدول‎ ٣ ع.حعىnہnNRP‎ 65 
. تستخدم لالإعلان عن كيفية ترتيب البيانات المسترجعة من الجدول‎ ORDER BY 
. اسم الحقل أو الحقول آو الآسماء المستعارة المراد الترتيب بها‎ c0اumn‎ or 5 


: اا ا ا عن عن يا امن 


ا 


تقنية الحاسب الآلي حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


کے 


متطلبات وإرشادات كتابة جمل 8Q1‏ . 


يوجد هناك بعض الإرشادات التي يجب مراعاتها عند كتابة جملة ]54 لتكون الجملة صحيحة 
وقابلة للتنفيذ › وهذه الإرشادات هي : 
١‏ - يمكن كتابة مكونات جملة SQ]‏ بالآحرف الكبيرة آو الصغيرة فهذا لا يؤثر على سلامة 
الجملة وذلك لآن جملة [اSQ۵‏ غير حساسة للجحرAaزف Not Case Sensitive‏ . 
١‏ فصل نن أسماء الحقول تاستخداء الفاصاة ( و .. 
۲ - يمكن كتابة جملة ]541 4 عدة سطور فهذا لا يؤثر ج صحة الجملة . 
٤‏ - لا يمكن فصل الكلمات المحجوزة للغفة أو اختصارها › والكلمات المحجوزة تسمى 
Keywords‏ وهي SELECT , FROM , WHERE , ORDER BY ) Jù‏ ( . 
۵ - يفضل كتابة الجملة على آسطر ليسهل قراءتها وفهمها . 
- لابد من الإعلان عن نهاية الجملة بواسطة ( و ) . 
۷ - ملحوظة : أوامر محرر 5Q0] * ۴110S‏ لا يوضع بعدها الفاصلة المنقوطة ( ; ) . 


گے 


لتنفيد جملة S1‏ : 
لتنفيذ جملة 8Q1‏ من الممكن استخدام إحدى الطرق التالية : 
١‏ - نضع الفاصلة المنقوطة ( ; ) 2 نهاية الجملة 
۲ - نضع علامة ( / ) 2 نهاية الجملة عند مؤشر < ا8 . 
"SO ae CRUN aN aA‏ 


ولفهم طبيعة جملة ]54 وكيفية تتفيذها » فسوف نقوم بعرض آمثلة لحالات الجملة ونتائج 
تنفيذها لنصل من خلال الأمثلة إلى الفهم المطلوب : 

قبل آن نبد 4 عرض الأمثلة هل تتذكر الجدولين المرسومين 2 الفصل السابق » كان الجدول 
الأول عبارة عن جدول يحتوي على بيانات الموظفين ويسمى ( ٤۴‏ ) » والجدول الثاني كان يحتوي على 
بیانات الإدارات ویسمی ( 0٤۲1‏ ) ( راجع صفحة ٦- ١‏ شكل (۳) ) وهنا سوف نستخدم هذين 
الجدولين بشكل آساسي ولذلك لابد من مراجعتهما ومعرفة آسماء الحقول ‏ كلا الجدولين . 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


کے 


مثال )١(‏ : عرض جميع الحقول من جدول الإدارات 0٤1‏ . 


SQL> SELECT * 
2 FROM dept ; 


DEPTNO 


ACCOUNTING | NEW YORK 
RESEARCH DALLAS 
SALES CHICAGO 
OPERATIONS BOSTON 


ے2 هذا المثال نقوم بعرض جميع الحقول والبيانات الموجودة 4 جدول الإدارات (٤1‏ الذي يحتوي 
على الأعمدة التالية ( 10° , DEPTNO , DNAME‏ ) وذلك باستخدام الرمز ( * ) والذي يعني 
إظهار جميع حقول الحجدول لاحظ أن أسماء RE‏ تظهر بالحروف الكبيرة 1 


مثال (۲) : عرض حقول معينة من جدول الإدارات 5٤۲۲‏ . 


SQL> SELECT deptno , dname 
2 FROM dept ; 


DEPTNO 


ACCOUNTING 
RESEARCH 
SALES 
OPERATIONS 


يوضح المثال السابق كيفية إظهار عدة حقول معينة من الجدول › ونلاحظ هنا بآن آسماء الحقول 
DEPT )‏ ( . 


6 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


استرجاع الحقول باسماء مستعارة( 6ه 1ا۸ ) : 

نستخدم طريقة الا اة المستعارة ) Aliases‏ ) عتدما رید إظهار الحقل باسم غير اسمه الموجود 2 
الحدول وذلك لتوضيح معنى الحقل مثلا . وهناك ثلاث طرق لإظهار الحقول باسماء مستعارة : 

۳ - استخدام علامة التتصيص المزدوجة التالية ( " ") عندما يكون الاسم المستعار أكثر 


ال( :+ فرض قول ناعماء مقار من جدول لر فن 


SQL> SELECT ename AS name , sal salary , job "employee job" 
2 FROM emp ; 


SALESMAN 


يوضح المثال السابق كيفية استخدام الطرق المختلفة لإظهار الحقول باسماء مستعارة › فنلاحظ 
هنا آن آسم الحقل 13۳۴ء قد ظهر 2 النتيجة باسم N.۸٤‏ بحروف كبيرة وكذلك حقل الراتب 
SAR ۷‏ » كما نلاحظ بأن الاسم المستعار الموجود بين علامتي التتصيص المزدوجة (" ") قد ظهر 2 
ال ها هو دون تحرلة آل الأحرف اكير 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


س کے 


استخدام العمليات الحسابية وأولويات تنفيذها مع جملة S£E1٤٣ ٣‏ : 


CNC GG LC N 
١١ إظهار الموظفين ورواتبهم 4 سنة فإنتانقوم بضرب راتقب كل موظف ج العمدد‎ 
ريال‎ ٠۰١ بشكل التالي ( 12* ]54 ) . وكذلك عند إظهار إجمالي الراتب لكل موظف بعد إضافة‎ 
لاحظ أن العمليات الحسابية على الحقول لا تؤثر على البيانات المخزنة داخل‎ . )5S4[ + 500 ( عليه‎ 
. الجدول‎ 
Arithmetic Operators ةبluحفنا المعاملات الحسابية التي تستخدم ے العمليات‎ 
.)+*( الجمع‎ - ١ 
< الطرح ر‎ < ١ 
.)* اليرت(‎ = ١ 
.)/( القسمة‎ - ¿٤ 
۴۸0M يمكن استخدام المعاملات الحسابية 2 جميع أجزاء جملة ]©8 ماعدا الجزء الخاص ب‎ 
. والأمثلة التالية توضح كيفية إجراء العمليات الحسابية على الحقول‎ 


مثال )٤(‏ : عرض رواتب الموظفين السنوية من جدول الموظفين 


SQL> SELECT ename , sal „, sal*12 "annual salary" 
2 FROM emp ; 


يبين المثال السابق كيفية استخدام العمليات الحسابية للحصول على رواتب الموظفبن السنوية وذلك 


بضرب راتب ڪل موظف ے4 ۱۲ شهر . 


١ 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


کے 
أولويات تنفيذ العوامJ‏ الجluيuة  Operator Precedence‏ 

عند إجراء عملية حسابية كبيرة على حقل من الحقول لابد أن تعرف كيفية حسابها ولمعرفة ذلك 
لابد أن تعرف أولوية تنفيذ العوامل داخل جملة ]5)0 فهي تنفذ بالترتب التالي : 

| اروت ية الاعات الاه لاضر بو ادمه ف الحم والرح. 

۲ - العمليات من نفس الأولوية تنفذ من اليسار إلى اليمين . 

N OG e LS 

IT 
اا ا‎ 


1 - 100*)40+10( = 100*50=5000 . 
2 - )100*40(+10 = 4000+10= 4010 . 


والمثال التالي يوضح آولوية التتفيكت للعوامل الحسابية . 


مثال )٥(‏ : عرض رواتب الموظفين السنوية من جدول الموظفين 

SQL> SELECT ename , sal, 12*sal+100 
a 

لال 


لاحظ اولوبة القفيد : 
العملية رقم )١(‏ تفذ آولاً ثم العملية رقم )١(‏ . 


2 FROM emp; 


لاحظ أولوية الت لتتفيك :+ 
العملية رقم ( 0 تفد ولا لوجود الأقرانن ته 
العملية رقم (۲) . 


Sl a OG Lg 
. المثال رقم (1) فتم حساب ما بداخل الأقواس أولا‎ 


- 


تقنية الحاسب الآلي ۱ حاب 
مقدمة قواعد بيانات أوراكل 


الفصل الثاني 
جملة الاستعلام الأساسية 


الرمجيات 


استخدام أداة الريط يبن الجحقول ( || ) Concaten2)i07‏ . 


لعمل سلسلة من الحقول نقوم بربط حقلبن أو أكتثر باستخدام أداة الربط ( || ) والتي تسمى 
Concaten 1‏ . ويكون ناتج الربط بين الحقول هو حقل واحد فقط » ومن الممكن آن نريط مع 


SQL> SELECT ename, job , enamejjjob as "employees" 
2 FROM emp ; 


employees 


SMITHCLERK 
ALLENSALESMAN 
WARDSALESMAN 
JONESMANAGER 
MARTINSALESMAN 


CLERK 
SALESMAN 
SALESMAN 
MANAGER 
SALESMAN 


ڪانهما حقل واحد باسم مستعار employees‏ يجمع يەن الاسم والوظيفة 1 


SQL> SELECT ename, job , ename||' is a '||[Job as "employees'"" 


employees 


SMITH 1s a CLERK 


ALLEN 1s a SALESMAN 
WARD 1s a SALESMAN 
JONES 1s a MANAGER 
MARTIN 1s a SALESMAN 


2 FROM emp ; 


CLERK 
SALESMAN 
SALESMAN 
MANAGER 
MARTIN SALESMAN 


2 المثال السابق تم ريط الحقلبن الاسم والوظيفة وبينهما نص هو (3 18) باستخدام أداة الربط 


( || ) > فظهر الناتج كما هو واضح بالمثال . 


YA = 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


استخدام عبارة (1S1 ٧1‏ لنع تكرارالسجلات : 
ا ا دک ا ت ا ا ادد د و اا و 


SQL> SELECT deptno 
2 FROMemp ; 


DEPTNO 


[ 5 لاحظ التكرار 2 أرقام الإدارات 


ارال هه وت د ها ص ر 2ا ا د اق ر 
التكرار نستخدم كلمة ( ٤٥«ذادزل‏ ) مباشرة بعد كلمة 1 S٤18٥‏ كماهو مبين 2 المثال التالي : 


SQL> SELECT DISTINCT deptno 
2 FROMemp ; 


DEPTNO 


= 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


س کے 


إظهارالبناء الداخلي للجداوJ‏ اتخ |ډÎمر DESCRIBE (DESC)‏ . 


IAN EG N O OE ES 
والذي اھ اڪ ن اختصاره ِ2 الآاحرف التالية‎ ( DESCRIBE للحدول لستخدم الآمر(‎ 
. ( DESC ) 


SQL> DESC emp ; 
NOT NULL NUMBER(4) 


VARCHAR2(10) 
VARCHAR2(9) 


NUMBER(4) 
HIREDATE DATE 
SAL NUMBER(7,2) 
COMM NUMBER(7,2) 
DEPTNO NUMBER(2) 


ب4 المشال السابق تم إظهار أسماء الحقول الموجودة ب4 جدول الموظفين وأنواعها وبعض المعلومات 
الخاصة بكل حقل مثل: هل نوع الحقل نصي أو تاريخ أو رقم 5 وما هو طوله 5 


التعامل مع القيمة N1‏ . 


ماذا تعني القيمة ]]لN‏ › هذه القيمة تسمى قيمة غير معروفة آو قيمة خاوية بمعنى آنها لاتساوي 
الصفر رلا ماف ورا ىرق ارت ٠‏ فا هات حل درل الرطفن اسه 00 هة الحقل 
EEE E EO E NEE‏ 
بدل تڪليف وموظفون آخرون لايمڪن تڪليفهم آي لايأخذون بدل تكليف إطلاقا و2 هذه الحالة يتم 
ترك حقل التكليف 00۷MM‏ خاليا ليس به آي قيمة ونطلق على القيمة الخالية هذه 11× . 


تقنية الحاسب الآلي ۱ حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


کے 


اال ا اتی نآ ارظن الذي لا كافون عمل إضا أن ل باخدرن يدل دين. 


SQL> SELECT ename, job , sal , comm 
2 FROM emp ; 


SALESMAN 

SALESMAN 

MANAGER 
MARTIN SALESMAN 
BLAKE MANAGER 
CLARK MANAGER 
SCOTT ANALYST 
KING PRESIDENT 
TURNER SALESMAN 


يمكك ن تلاحجط متا الطت 116 لا خد يدل كيت و الك رك COMM ao‏ 
E‏ 

E OO IL E 
: تلاحظ ذلك ب المثال التالي‎ 


SQL> SELECT ename, job , sal, 12*sal+comm 
2 FROM emp ; 


12*SAL+COMM 


SMITH CLERK 
ALLEN SALESMAN 1600 


SE 


تقنية الحاسب الآلي حاب الفصل الثاني 
الارمجيات مقدمة قواعد بيانات أوراكل حملة الاستعلام الأساسية 


أسنلة الفصل الثانى 
EEE ES‏ 


Name Null? Type 
DEPTNO NOT NULL NUMBER(2) 
DNAME VARCHAR2(14) 
LOC VARCHAR2(13) 


۲ - اكتب جملة استعلام لعرض أسماء ووظائف وتواريخ تعيين وأرقام الموظفين بحيث يظهر رقم الموظف 
أولاً ‏ 


ANALYST 


CLERK 
MANAGER 
PRESIDENT 
SALESMAN 


س اڪتب جملة استعلام لعرض آرقام الموظفىن وآسمائهم ووظائفهم مع تغيير آسماء الآأعمدة ڪمها هي 
4 النتيجة التالية : 
EMPLOYEE NO | EMPLOYEE NAME | JOBS‏ 


7369 | SMITH CLERK 
7499 | ALLEN SALESMAN 


7521 | WARD SALESMAN 
7566 | JONES MANAGER 
7654 | MARTIN SALESMAN 
7698 | BLAKE MANAGER 


E 


مقدمة فواعد بيانات أوراكل 


حصر وترنیب البيانات 


frmBmıi [Code] 


1 Len (rallsg) = I) FA Project - {Code} 
Sereen, HousePointer +, | [emacne 


| | PEivwate Sub cmAlalc Z| 

trmMDI.stsdtatusPar, 1 2 ERE 
EL 

If tPausêflagf The 


End Sub 


Else 


AS UT OT 


z2 Fh E] ھک‎ @ ¢ 


CRIPT larguage="davaSeript"> 
nt iH animateAnChor ld { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


حصر ونرنيب البيانات 
RESTRICTING AND SORTING DATA‏ 


الجدارة : 
استرجاع البيانات بشروط لما وترتيبها (حصر البيانات وترتيبها ) 
الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على : 
١‏ -فهم جملة الشرط ( WHE٤R ٤‏ ) لحصر البیانات . 
-معرفة واستخدام معاملات المقارنة ۲2)0۲Sءم0 comparison‏ 2 جملة الشرط . 
٣‏ -معرفة واستخدام معاملات المقارنة الخاصة ) (In, Between, Like,Is Null‏ . 
٤‏ -معرفة واستخدام المعاملات المنطقية ( AND,OR,N01‏ (. 
۵ -استرجاع الصفوف بشكڪل مرتب تصاعديا أو تنازليا حسب عمود معين. 
٦‏ -استرجاع الصفوف بشڪل مرتب حسب عمودين آو آڪٽر. 


مستوى الأداء المطلوب : 
آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 


الوقت المتوقع للتدريب : آربع ساعات 


الوسائل المساعدة : 


. حاسب آلي‎ e 
. قلم‎ ê 
دفتر.‎ ۵ 
: متطلبات الجدارة‎ 
DEPT , EMP ڌةaدختu.nقlاl‎ Jوادجلا الآأساسية « معرفة‎ SE] ٤٣1 القدرة على التعامل مع جملة‎ 
. وآسماء الحقول و خصائصها وآنواع البيانات داخلها‎ 


e 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


کے 


الفصل الثالث : مقدمة 


فل الاو ارغ 0 وای ا E‏ 
NL N TET O Se E a‏ 
i Ea e NS N E o‏ 
وتكون هذه الاسماء مرتبة تصاعدياً أو تنازليا حسب راتب كل منهم » فماذا نعمل حتى نستطيع 
ao‏ 

N E Ea a‏ اجر لوي ا ا 
ORDER BT E E aaa as u a‏ 


حمل الشرط WHERE)‏ (: 


e EES a ERODES aS 

شروط معينة » ويتكون الشرط من طرفين بينهم معامل مقارنة 06130۲ C0 P210۸‏ » وعند 
تحقق الشرط آي إن الشرط (۲۸0۴) فإن جملة S۴1 ۴٣1‏ يكون لہا ناتج » آما إذا كان ناتج الشرط 
غیر متحقق )۴۲۸158٤(‏ فإن جملة SE] ۴٤٥1‏ لا يڪون لہا أي ناتج وتظهر رllıة No Row Selected)‏ ( 


: WHERE طرشlا‎ îlaج مكونات‎ 


يمكن آن تحتوي جملة الشرط )۷10۲١(‏ على ما يلي : 
۵ آسماء حقول um۸sآەC‏ . 
® معاملات مةlaرiة Comparison Operato1s‏ . 
قيم ثابتة سواء كانت عددية أو نصية . 


2 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


کے 


متطلبات وإرشادات كتابة جمlة‏ الشرط WHERE‏ . 


يجب مراعاة الآتي عند كتابة جملة الشرط . 

عند استخدام قيم نصية أو قيم تعبر عن تاريخ لابد من وضعها داخل علامة التتصيص 
الفردية(' ') . 

6 2 حالة استخدام القيم النصية لابد من مراعاة حالة الأحرف كبيرة آم صغيرة . 

2 حالة استخدام قيم تمبرعن تاريخ لابد من مراعاة صيغة التاريخ المستخدمة 
(۴۴41 ) علما بأن الصيغة الأساسية للتاريخ داخل لفة 8Q]‏ هي كالتالي : 
DD-MON-YY ‹‏ ) حيث إن ( 02 تعبرعن اليوم > ١×0١‏ تعبرعن الشهر » ۲۷ تعبر 
CS‏ 


: ) ORDER BY ) qaتjîlا جم‎ 


تستخدم هذه ال لجملة لترتيب الصفوف الناتجة ترتيبا تصاعديا أو تنازليا » وتكتب دائما ب2 نهاية 
جale SELECT‏ . 


متطلبات وارشادات كتابة جملة اتيب ORDER BY‏ . 


يجب مراعاة الآتي عند كتابة جملة الترتيب . 
۵ يجب أن تثڪتب ے2 آخر جملة SELECT‏ . 
۵ تحتوي على آسماء حقول كصصuںآه‏ آو آسماء مستعارة ؟ع1اA‏ . 
E N 8‏ أكتب (45€0 ) وهي اختصار لكلمة ( )۸8٥٥1d1١g‏ وهي القيمة 
الافتراضية للترتيب (1اة۴ء0) . 
8 للترتيب ا لابد من كتابة )(0٤5€(‏ وهي اختصار لكلمة 108”ءءءم0 . 


- ° 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


مثال )١(‏ : عرض أسماء و وظائف وأرقام إدارات الموظفين الذين يعملون بوظيفة ( 1ER K۸‏ €) » مع 


ترتیب الناتج ا عد حسب رفم الادارة 


SQL> SELECT ename , Job , deptno 
2 FROM emp 
3 WHERE job ='CLERK' 
4 ORDER BY deptno 


MILLER 
SMITH ٤ 
JAMES 


TEE 
E 
E 


المثال رقم )١(‏ يببن طريقة استخدام جملة الشرط ١۲ء۷1‏ . وذلك لعرض بيانات الموظفين الذين 
مون 2 E‏ فط ٠‏ لاح آنه ارط فد حر عل رفن بها مال حاب 
وهو (<) » وكانت النتيجة كما هي واضحة 2 المثال وذلك لأن جملة الشرط قد تحققت وكان هناك 
موظفون يعملون بوظيفة C18۸)‏ » لاحظ أيضا أن الطرف الثاني من جملة الشرط ا 5) قد 
اشتخدمنا فيه ثابتا نصيا و وضعنا هذا الثابت بين علامتى التنصيص الفردية ٠‏ وآيضا كتبنا الثابت 
النصي بالآأحرف الكبيرة وذلك لأن البيانات داخل جدول الموظفين مسجلة بالآأحرف الكبيرة ولذلك 
لابد من مراعاة حالة حرف البيانات داخل الجدول كبيرة آم صغيرة حسب ماهو موجود 2 الجدول . 
ڪما تم ترتيب الناتج تصاعديأ بوılطة ORDER BY‏ . 


معاملات المقارنة المستخدمة في جم اllشرط Comparison Operators . Where‏ 


تستخدم معاملات المقارنة التالية للمقارنة بين طرے الشرط 2 جملة W1۴1‏ 
اا ی 


E as 
من‎ n 


يسا 
: 
آڪبر من او يساوي 
آقل من آو يساوي 

چ آو كا لایساوی 


ا 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


کے 


الصيغة العامة لج الشرط WHERE‏ 


SQL > WHERE yı: OPERATOR 


أمثلة مختلفة : 
بشرط آن تاریخ التعیین يساوي ( ۱ ینایر WHERE hıiredate = '01-JAN-95' )٩٥‏ - 


بشرط أن الراتب أڪبر من أو يساوي ٠٠۰۰‏ دولار . 1500 => WHERE sal‏ - 
بشرط أن سم الموظف يكون WHERE ename = 'SMITH' SMITH‏ - 


مثال (۲) :+ عرض أسماء و وظائف ورواتب الموظفىن الذين رواتبهم آڪبر من او تساوي 0 . 


SQL> SELECT ename , job , sal 
2 FROM emp 
3 WHERE sal >= 3000 ; 


ANALYST 


PRESIDENT Ee aî 
ANALYST 


مثال (۳) : عرض أسماء و رواتب وعمولة الموظفين الذين رواتبهم آقل من او تساوي العمولة الخاصة 


بهم . 


E 


ا 


SQL> SELECT ename , sal , comm 
2 FROM emp 
3 WHERE  sal<= comm ; 


2 


2 


E 


E 


1 


2 


2 


1 


2 


E 


2 


MARTIN 1250 1400 


N 


لي حاب الفصل الثالث 


الارمجيات مقدمة قواعد بيانات أوراكل حصر وترتیب البيانات 


الممكن أن نستخدم أسماء الأعمدة للمقارنة للمقارنة مع آسماء آعمدة آخرى . وكانت النتيجة هي عرض 
بیانات الموظفىن الذين رواتبهم آقل من آو تساوي العمولة الخاصة بهم : 


معاملات مقارنة آخرى تستخدم في جملة الشرط WHERE‏ . 


هناك معاملات مقارنة آخرى تستخدم 2 جملة الشرط هذه المعاملات تسهل عملية حصر البيانات 


کل آ کر و ھی الى 


BETWEEN ta AND u 


و %0 1 LIKE‏ حصر البيانات حسب مطابقة َة النص أو الحروف 
IS NULL‏ خض ر اتات انها اا N‏ 


SQL> SELECT ename , sal 
2 FROM emp 
3 WHERE sal BETWEEN 1500 AND 2500 ; 


2 المثال السابق تم عرض بيانات الموظفين الذين تتحصر رواتبهم بين ٠٠٠١‏ و ۲٠٠١‏ » لاحظ أن 
القيمة ٠٠٠١‏ قد ظهرت 2 النتيجة لأن ناتج جملة B۴ W۴۴۸‏ يشتمل على القيمة الصغرى والقيمة 
الكبرى » ونؤكد هنا على آن القيمة الصغرى لابد آن تكون آقل من القيمة الكبرى . فإذا عڪسنا 
القيمة الكبرى مكان الصغرى ( 1500 BETWEEN 2500 ۸N‏ ) فإن جملة الشرط لن تتحقق آي 


تکون قیمتها )۴۸15۴٤(‏ وتظھر رسالة (dء†cء[eء5 N0 RW‏ ) ومعناها لم یتم تحدید آي صف . 
YA‏ 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


مثال (0) : عرض رقم وأسم وراتب ورقم المدير للموظفين الذين لديهم مديرين بالأرقام التالية 
(VVAA g Vol g ۷۹۰۲(‏ 


SQL> SELECT empno , ename , sal, mgr 
2 FROM emp 
3 WHERE mgr IN (7902,7566,7788,7839) ; 


ج المتال السابق تم استرجاع بيانات الموظفين الذين لديهم مديرين من بين الأرقام التالية : 
)۷4۰ و9 011 ۾ LaÎ( VVA^‏ المدير ذو الرقم (۷۸۹) فليس لديه موظفبن لذلك لا يوجد له نتيجة . 


وبهذا فإن جملة 1١‏ تقوم بالبحث عن الرقم من بين قائمة الأرقام الموجودة داخل الأقواس . 
عامل } _ ,% LIKE{‏ . 


النص المذكورة ے2 جملة الشرط . 


+ (%) هذا الرمزيعني أي حرف أو حرف a A CA CA a‏ 
بحرف ۸ مهما كانت باقى الحروف التالية له . فهو يستخدم للبحث عن نص يبدا بالحرف ۸ . 


التعبير ( %۸ ') يعنى مطابقة ال ا ف ۸ مھما کانت | EN E‏ 
واللعبي يعني مطاد ص التي لهي بحر 9 ي لس 
آما التعبير )/%4۸%١(‏ فهو يستخدم للبحث عن النصوص التي تحتوي على الحرفق ۸ . 


ل 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


کے 
Ey ES CAN ES TONS) SS‏ 
الحرف الأول» ويستخدم هذا التعبير عندما نريد البحث عن نص يكون الحرف الثاني فيه هو ۸ . 
آما التعبير ( ۸_ _') » فيستخدم للبحث عن نص يكون الحرف الثالث فيه هو ۸ . 
ملحوظة : 
يجب مراعاة حالة الأحرف هل هي كبيرة آم صغيرة عند استخدام المعامل 16٤‏ . 
مثال (1) : عرض أسماء الموظفين الذين تبداً أسمائهم بالحرف 8 . 


SQL> SELECT ename 
2 FROM emp 
3 WHERE ename LIKE 'S%' ; 


مثال (۷) : عرض أسم وتاريخ تعيين الموظفين الذين تم تعيينهم 2 العام ۱۹۸١‏ م 


SQL> SELECT ename , hiredate 
2 FROM emp 
3 WHERE hiredate LIKE '%81' ; 


HIREDATE 


20/02/81 
22/02/81 
02/04/81 
28/09/81 
01/05/81 
09/06/81 
17/11/81 
08/09/81 
03/12/81 
03/12/81 


E E E E E E E E E E E E E E E E E E E E E E E E E E 
e e SRR e Ss Re e SR e Sh Re ES RRA E RS ARR RS E 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


کے 


مثال (۸) : عرض أسماء الموظفين الذين يكون الحرف الثاني 2 أسمائهم هو ۸ . 


SQL> SELECT ename 
2 FROM emp 
3 WHERE ename LIKE ' A%' ; 


الحرف الثاني ( ۸ ) 
WAÃRD‏ 


MARTIN 
JAMES 


4 المثال السابق تم البحث عن الاسماء التي يكون الحرف الثاني فيها هو ( ۸ ) ثم عرض هذه 
الا 


SQL> SELECT ename , mgr 
2 FROM emp 
3 WHERE mgr IS NULL ; 


2 المثال رقم (۹) تم استخدام المعامل N1011‏ 18 والذي يقوم بحصر البيانات الخالية › ففي المثال 
تم عرض بيانات الموظفين الذين لا يوجد لديهم مدير آي إن حقل المدير( ١6R‏ ) لهذا الموظف خالي ليس 
به بیانات . 

ملحوظة : 

لا يمكن استخدام المعامل (<) مع القيم الخالية N01‏ ولكن لابد من استخدام المعامل 
ا11 18 . يمكن آن تجرب الآمر 2 المثال السابق بالشكل التالي لتعرف الفرق 5 


الأمر هنا خطاً لاستخدام المعامل ( =) SQL> SELECT ename , mgr‏ 


2 FROM emp ا‎ 


3 WHERE mgr = NULL; 


E 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


کے 


المعاملات المنطفية في جîl‏ ارط WHERE‏ . 


تربط بين جملتين شرطيتين آو آكثر وتكون النتيجة آما (٤ل1۸)‏ آي تحقق الشرط 
أو (۴۸188) لم يتحقق الشرط 


: AND Jلماعملا‎ 


هذا المعامل یربط بین جملتبن شرطيتبن ويڪون الناتج 1۸0۴ إذا حانت كلتا الجملتىن ٤0ا1۸‏ . 
والجدول التالي يوضح ناتج المعامل ۸[١N(‏ مع الحالات المختلفة لجملتي الشرط . 


SE EET 


E a E 

ولا 7ت ND‏ بك FASÊ: i5‏ إل اة أن ال ن 1۸08 فط . 

افا + عند نخدم نة 1[ N10‏ م المعامل ۸5 يون الات د انعا N01‏ الا عا ان 
احدى الجملتىن تكون -ااN01‏ والآخری ۴۸18۴ فقط . 


Ta 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


مثال )٠١(‏ : عرض رقم وآسم ووظيفة وراتب الموظفين الذين رواتبهم أكبر من آو تساوي 1100 وج نفس 
الوقت وظıتr CLERK‏ . 


SQL> SELECT empno , ename , job , sal 
2 FROM emp 
3 WHERE sal >=1100 AND job="'CLERK' ; 


T | T | 
جملة‎ 


جملة 


MILLER 


المثال السابق يبين آن جملتي الشرط 1100=<اaء‏ و ')R٤ا)"-طمز‏ قد تحققت آي إن نتيجة 


TRO RD a EE AS CRU E, a‏ د ‏ غرکن 
Sa‏ 


SQL> SELECT ename , sal , comm 
2 FROM emp 
3 WHERE sal<>1100 AND comm<500 ; 


ALLEN 1600 
TURNER 1500 


TT 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


المعامل O۸‏ :+ 
هذا المعامل یربط بین جملتبن شرطیتین ويڪون الناتج 180۴ إذا كانت إحدى الجملتين آو 


E e N E E 
. إلا 4 حالة أن الجملتین ۴۸18۴ فقط‎ R0۴٤ أولاً : ناتج العامل 0۸ یکون داتماً‎ 

Ss = RUEE E Ss ORAS OLE SS E 
. 1R 1۴٤ فقط فیڪون الناتج‎ 1۸0۴٤ والآخری‎ N01 إحدى الجملتین تكون‎ 


\ 


مثال (۱۲) : عرض رقم وسم ووظيفة وراتب الموظفين الذين رواتبهم أكڪبرمن (2500) أو تڪون 
وظیفتھم MANAGFR‏ . 


SQL> SELECT empno , ename , Job , sal 
2 FROM emp 
3 WHERE sal >2500 OR Jjob="MANAGER' ; 


MANAGER 


MANAGER 
MANAGER 
ANALYST 
PRESIDENT 
ANALYST 


a 


تقنية الحاسب الآلي الفصل الثالث 
حصر وترنيب البيانات 


الرمجيات مقدمة قواعد بيانات أوراكل 
المثال السابق يبين آنه لابد من تحقق آي من الجملتين حتى يتم استرجاع بيانات »› وبالتدفيق 2 


۱ حاب 


شرط الوظيفة ( [N46۴8‏ ) » أي إنه يجب أن يتحقق أحد الشرطبن لاسترجاع البيانات . 


مثال (۱۳) : عرض آسم وراتب ورقم الإدارة للموظفين الذين رواتبهم قل من (1000) أو تڪون ٳداراتهم 


رقم (10) . 


SQL> SELECT ename , sal , deptno 
2 FROM emp 


3 WHERE sal<1000 OR deptno=10 ; 


SGN NB E 

الإدارة رقم )٠١(‏ . نلاحظ من المثال أن الموظفين المسجلين 2 الإدارة رقم ٠١‏ يأخذون راتبا أقل من 

وای الین ادون راف كر من ١:‏ هو مان لار ركه( 0 وها دك 
آنه لاسترجاع بيانات لابد من تحقق إحدى جملتي الشرط على الأقل . 


: NOT Jl0 


2 TO 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 


البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


يستخدم المعامل N.01‏ أيضا لنفي المعاملات الموضحة بالجدول التالي : 


| 
1S NOT NULL 


آمثلة على استخدام المعامل N.01‏ لعكس المعاملات السابقة الذكر . 


WHERE job NOT IN (CLERK' ,'MANAGER' ) 
WHERE sal NOT BEIWEEN 1000 AND 1500 
WHREE ename NOT LIKE '/A% 

WHERE comm IS NOT NULL 


. (CLERK , MANAGER , ANALYST ) 
SQL> SELECT ename , job 


2 FROM emp 
3 WHERE job NOT IN ('CLERK' , 'MANAGER','ANALYST'); 


SALESMAN 
SALESMAN 
SALESMAN 
PRESIDENT 
SALESMAN 


2 هذا المثال تم نفي المعامل ( ... )11 ولذلك تم عرض بيانات الموظفين الذين لم وظائف ليست 
من ضمن قائمة الوظائف |لتlنıة‏ ) (CLERK , MANAGER , ANALYST‏ . 


TS 


تقنية الحاسب الآلي حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصر وترتيب البيانات 


5 :عرش ا ورک ورات رطفن الذن ي تر رو ا بن 1000 5000 : 


SQL> SELECT ename , job , sal 
2 FROM emp 
3 WHERE sal NOT BETWEEN 1000 AND 3000 ; 


CLERK 
PRESIDENT 
CLERK 


ج المثال السابق تم استبعاد الموظفين الذين تنحصر رواتبهم بين ٠٠٠٠١‏ و Tits‏ > ونم عرض باقي 
الموظفين . وبذلك قد تم نفى المعامJ‏ ) .... BETWEEN ... AND‏ ( . 


مثال )١(‏ : عرض أسم ووظيفة وراتب وعمولة الموظفين الذين يأخذون عمولة . 


SQL> SELECT ename , Job , sal, comm 
2 FROM emp 
3 WHERE comm IS NOT NULL ; 


SALESMAN 
WARD SALESMAN 
MARTIN j SALESMAN 
TURNER | SALESMAN 


2 المثال السابق تم عرض بيانات الموظفين الذين يآخذون عمولة » آي الذين ليست عمولتهم خالية 
NULL‏ . 


N LENET eas OEE ES 
ORDER BY sal DESC 


TV = 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


کے 
أسئلة الفصل الثالث 


بحيث تظهر النتيجة كالتالى : 


MARTIN 
SCOTT 
KING 
ADAMS 
JAMES 
FORD 
MILLER 


الإدارة رقم 10 أو مسجلين 2 الإدارة رقم 30 والنتيجة مرتبة تنازليا حسب الراتب ؟ بحيث تظهر النتيجة 
كالتالى : 


هھ 


- ۳A - 


تقنية الحاسب الآلي ۱ حاب الفصل الثالث 
البرمجيات مقدمة قواعد بيانات أوراكل حصروترتيب البيانات 


النتيجة كالتالى : 


النتيجة كالتالى : 


TURNER 
MARTIN 
WARD 


النتيجة كالتالى : 


ALLEN 
MILLER 


TA 


مقدمة فواعد بيانات أوراكل 


دوال الصف الواحد 


E Project - : frmB mi [Cade] 


1î Len(rslsg) = Û Terk 
Sereen, HousePointer | ERE : 
ttrmMDI.stsStatusfar. i 12 


NEL 
If tPausêflagf The 


Private 21D cmdvLalz | 


End Sub 


Else 


ت ا ھک کد z2 Fh E]‏ 


CRIPT larguage="davaSeript"> 
iHSZLEion animateAnChor ll { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 


IF [("A'==e1],TtagMame} { 
iF Inull==el]l.effECTE] El.EffECTE = 


yj Initialize effect 
" h1 ql 3 


تقنية الجاسب الآلي ۱ حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


کے 
دوال الصف الواحد 


SINGLE-ROW FUNCTIONS 


الجدارة : 


الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على: 
١‏ -معرفة الدوال المستخدمة 2 لغة الاستفسارات ([50) وأنواعها. 
۲ -معرفة آنواع دوال الصف الاد Single-Row Funct1ons‏ . 
۳ -معرفة واستخدام الدوال انحرaùية Character Funct1ons‏ . 
¿٤‏ -معرفة واستخدام الدوال الرقnمية Number Funct1ons‏ . 
۵ه -معرفة واستخدام دوال تاريخ Date Func(10¬s‏ . 


. Converslon FuUnC101S Jıgحتll‎ Jلاود -معرفة واستخدام‎ ٦ 


مستوى الأداء المطلوب : 
آن يصل المتدرب إلى إتقان هذه الجدارة 1/٠٠١‏ . 


الوقت المتوقع للتدريب + آربع ساعات 


الوسائل المساعدة : 


© فلم . 
8 دفتر. 
متطلبات الجدارة : 


E 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


کے 
الفصل الرالع : مغدمة 


توجد دوال تستخدم داخل لغة اللاستفسارات تىمى UN€C110×8‏ ° ا58Q‏ وهذہالدوال تعتبر أآداة 
فوية ومفيدة عند استخدام جملة SELECT‏ « وتنقسم هده الدوال ا نوعين ڪما هو میہن 2 الشكڪل 
التالى: 


SQL FUNCTIONS 


یڈ 


صف 


فیمه 
lحد a SINGLE-ROW‏ واحد 
FUNCTION‏ 


النوع الأول : يسمى دوال الصف الواحد SINGLE ROW FUNCTIONS‏ وهذا النوع یقوم 


بالتعامل مع بيانات صف واحد فقط لآخراج قيمة واحدة وهو الذي سيتم شرحه بالتقصيل 4 هذا 
الفصل . 

النوع الثاني : يسمى الدوال التجميعية لاآاڪiر jn‏ صڊٺ MULTIPLE ROW FUNCTION‏ 
وهذا النوع يقوم بالتعامل مع بيانات أكثر من صف لآخراج قيمة واحدة فقط وسوف يتم شرحه 2 الفصل 
القادم بإذن الله . 


E 


تقنية الحاسب الآلي ۱ حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 
دوال الصف llأوا<d‏ : Single-Row Functions‏ 
وهي كما ذكرنا عبارة عن دوال تتعامل مع بيانات صف واحد فقط وتكون نتيجتها قيمة واحدة 
فقط › وتستخدم 4 آي مڪان من جملة luc ln SELECT‏ الحزء FROM‏ « وتنفسم ا عده آنواع ھی ` 


. Character Funct101S ةuhرح‎ Jلاود‎ 

. Number Funct10‹1S رة‎ Jاود‎ 

. Date Functlons تاريخ‎ Jlaد‎ 

. Converslon FUNC101S Jıgحت‎ Jlaد‎ 


الدوال الجرفية : Character Functions‏ 
وهي دوال تتعامل مع البيانات الحرفية وتكون نتيجتها إما حروفا أو أرقاما . والجدول التالي يبين 
جميع الدوال الحرفية ووظيفة كل منها . 


FUNCION aw 


ا ف( د أو سلسلة) إ ف 

LOWER(columnl\expression) ااا و‎ 
صعبره‎ 
UPPER(column\expression) ا ا‎ ٤ ٣ 
apita 


ELS E A a US 
INITCAP(column\express1ion) ل‎ 
حرف كبير 03141 وباقي الحروف تحول إلى حروف صغيرة‎ 
CONCAT(column1\express1ion1l, CDSS RG US 
Column2\express1on2 


دالة تستخدم لإيجاد عدد حروف السلسلة آو العمود (الناتج عدد ) LENGTH(column\express1on)‏ 


دالة تستخدم لتحديد مكان حرف معبن داخل سلسلة أو عمود [ 
( الناتج عدد والحرف 11 يعبر عن الحرف المراد تحديد مكانه DS‏ 


دالة تستخدم لقطع جزء من ANS e E‏ 
SUBSTR(column\expression,m,n) ٤‏ 
وعدد الحروف المقطوعة هي 1 
دالة تستخد لضبط بيانات عمود أو سلسلة ناحية اليمين وذلك بملء ٠‏ 
LPAD(column\express1on,n,'string!') 1 ٣‏ 
حرف معبن من اليسار والحرف 1 لتحديد الطول بعد الضبط 


بملء حرق معين من اليمين والحرف 1 لتحديد الطول بعد الضبط 
دالة تستخدم لقطع حرف معين من بداية آو نهاية الكلمة فقط TRIM(‘character' FROM column\express1lon)‏ 


RPAD(column\expression,n,'string') 


ET 


تقنية الجاسب الآلي ۱ حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


والجحدول التالي يحتوي على آمثلة لكل دالة من الدوال الحرفية مع النتيجة لكل منها : 


Select SUBSTR(GOOD BY',2,3) from dual; ____ OOD 
Select LPAD(AHMED',10,'*') from dual ; 
Select RPAD(AHMED',10,'*') from dual ; 
Select TRIM('S' FROM 'SAMI') from dual: 


التي لا يدخل فيها آي جدول من داخل قاعدة البيانات . 


بعض الأمثلة على الدوال الحرفية . 


SQL> SELECT LOWER(ename) , UPPER(job) , INIT'CAP(job) , CONCAT(ename, job) 
2 FROM emp 
3 WHERE sal=3000 ; 


LOWER(ENAME) | UPPER(JOB) Î INITCAP(OJOB) | CONCAT(ENAME, JOB) 


scott ANALYST Analyst SCOTTANALYST 
ford ANALYST Analyst FORDANALYST 


TS ا‎ TT ا‎ EE 


ے المثال السابق نم عرض أسماء الموظفىن بالحروف الصغيرة ووظائفهم بالحروف الكبيرة اا 
وظائفهم بحيث يكون الحرف الأول كبيرا والباقي صغيرا وربطنا بين آسماء الموظفين ووظاتفهم لعرضهم 
کصف واحد 1 


E E 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


مثال (۲) : 


SQL> SELECT ename,SUBSTR(ename,2,3), LENGTH(ename),INSTR(ename,'K') 
2 FROM emp 
3 WHERE LOWER( job)='manager' ; 


SUBSTR(ENAME,2,3) LENGTH(ENAME) | INSTR (ENAME, 'K') 


شرح مثال (۲) : 
سوف نقوم بشرح كل جزء من جملة S٤1 ٤C1‏ السابقة على حده حتى يسهل فهم عمل 
كل دالة . 


2 الجزء الأول (8 N۸۷‏ ع) تم عرض أسماء الموظفين وذلك لمعرفة تأثير الدوال عليه . 

4 الجزء الثانی S18S1۸)8N۸4M٤,2,3(‏ تم عرض جزء من الاسماء بداية من الحرف رقم 
(۲) من اليسار وعدد الحروف المقطوعة (۳) أحرف بفعل الدالة 81881۴ والتي تقوم بقطع 
جزء معين من الكلمة . 

الجر انالك من اهال ته عر هد ا حر ا ا ل ا 601711 1 
کو و 

NE E E O a E 
بقعل الذالة 187۸ فنلاحظ أن ترتیب الحرف × دانخل اسم الوظت ۸۴۔8 هو الرابع بينما‎ 
. هو الخامس‎ C۸۸) ترتيبه داخل آسم الموظف‎ 

لاحظ إننا قد استخدمنا الدالة 10۷۴۴ ي جملة الشرط ۷18R۴‏ وذلك لتفادي الخطاً 


الذي ينتج من عدم معرفة حالة الحروف المكتوبة 4 الجدول . 


O 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 
مثال (۳) : 


SQL>SELECT ename, TRIM('S' FROM ename), LPAD(ename,10,'*') , RPAD(ename,10,'#') ٤ 
3 WHERE sal><2500 ; 


TRIM(S' FROM ENAME) | LPAD(ENAME,10,*') | LPAD(ENAME,10,#') 


+k JONES JONESHHHHH 
+k BIA KE BLAKE##### 
+ x ** SCOTT SCOTTHHHHH 
1 kk KING KING#HHHHH 
+ 4% + * FORD FORDHHHHHH 


0 

ے الجزء الأول )EN۸١٧N٤(‏ تم عرض أسماء الموظفين وذلك لمعرفة تأثير الدوال عليه . 

ه ب الجزء الثاني من المڻال RM) S' FROM ENA ME)‏ تم عرض الاسماء بعد قص الحرف $ 
من بدايتها أو نهايتها وذلك بفعل الدالة 1۸1١۷‏ فنلاحظ أن الموظف ؟٤N١0[‏ قد تم قص الحرف 
ا ا ا 00 ت قفن تحرف 5 شن دا 

ے الجزء الثالث (*',10, PAD) N۸٤‏ تم عرض آسماء الموظفين بعد إضافة عدد من الرمز 
SEN KEELE INR eae a aN‏ 
08[ عبارة عن خمسة آحرف وبفعل الدالة ۴42[ قد تم إضافة الرمز (*) خمسة مرات من 
N AAS a EE ae‏ 
(right-justifled)‏ . 

الجزء الرابع (# ,۴,10 RAD) ENAM‏ يماثل تماما الجزء الثالث ولكن إضافة الرمز (#) إلى 
ا ت و ا ا و 
(left-justifled)‏ . 


NEG EET EE A a 
. FROM 


ا 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


Number Functions : رأة‎ Jاودلا‎ 


وهي دوال تعمل مع البيانات الرقمية وتكون نتيجتها آرقاما فقط . والجدول التالي يبين جميع 
الدوال الرقمية ووظيفة ڪل منها . 


دالة تستخدم لقص عدد معين من الجزء العشري مع تقريب الآعداد إلى 
أقرب عدد العشري أو إلى عدد صحيح والحرف 1 يبين عدد الأرقام بعد 
العلامة العشرية › وتوجد حالات للحرف 1 . 
ا د 
إذا كان (1<0) آي عدد موجب فإن التقريب يكون ك الجزء 
بعد العلامة العشرية ( الجزء العشري) . 
إذا ڪان (1>0) آي عدد سالب فإن التقريب يكون 2 الجزء 
قبل العلامة العشرية (الجزء الصحيح ) . 


ROUND(column\express1on,n) 


دالة تستخدم لقص عدد معين من الجزء العشري بدون تقريب › وآيضا 
توجد حالات للحرف ١1‏ . 
اذا ڪان )٥<0(‏ فإنه يتم قص الجزء العشري ڪله ويڪون 
الناتج عدد صحيح . 
إذا كان (0<0) آي عدد موجب فإن القص يكڪون ے2 الجزء بعد 
العلامة العشرية ( الجزء العشري) . 
إذا كان (0>0) أي عدد سالب فإن القص يكون 4 الجزء قبل 
العلامة العشرية (الجزء الصحيح ) . 


TRUNC(column\express1on,n) 


دالة تستخدم لإيجاد باقى قسمة العدد 10 على العدد ۸ . 


ENS 


تقنية الحاسب الآلي حاب الفصل الرابع 


الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


SQL>SELECT ROUND(45.923,0),ROUND(45.923,2),ROUND(45.923,-1),ROUND(45.923,-2) 
2 FROM dual; 
العداد‎ 


المثال السابق يوضح تأثير استخدام الدالة الرقمية ۸002 على الأرقام » فتنجد آنه عندما كانت 
قيمة 1۸ مساوية للصفر فإنه تم التقريب إلى عدد صحيح فكانت النتيجة مساوية »)٤1(‏ وعندما كانت 1 
تساوي العدد (۲) فإنه تم التقريب إلى عددين عشريين فكانت النتيجة )٤0,۹4۲(‏ » وعندما كانت 1 
تساوي ( )١١‏ فإن التقريب تم على الجزء قبل العلامة العشرية 2 العدد (0) فأصبحت النتيجة )0١(‏ › 
ونلاحظ آنه عندما كانت 1 تساوي ( )۲١‏ فإنه تم تقريب العدد )٠٠١(‏ إلى الصفر وذلك لأن العدد )٤٥(‏ 
آقل من )٥۰(‏ لآننا نقرب إلى مثات . 


: )٥( مثال‎ 


SQL> SELECT TRUNC(45.923,0), TRUNC(45.923,2),TRUNC(45.923,-1),TRUNC(45.923,-2) 
2 FROM dual; 


TRUNC(45.923,0) | TRUNC(45.923,2) | TRUNC(45.923,-1) | TRUNC(45.923,-2) 


ال العا وك ار اا ا0 ا ار قا کی و کا 
مساو اشر ته قى نادرى ةما كافة 1 ارون ٠‏ فاتةت فص لدد الف 
ليصبح رقمين فقط » عندما كانت 1 تساوي ( )١-‏ تم قص العدد )٥(‏ من الجزء قبل العلامة العشرية 
قكانت النتيجة ( 5ء وعندما كانت 1 اوي ( -) فإنه تم ق العدد الصجيخ قاأصبع ضفرا : 


- <A - 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


SQL> SELECT ename , sal, comm , MOD(sal,comm) 


2 FROM emp 
3 WHERE sal=1600 ; 


SAL Î COMM |] MOD(SAL,COMM) 


ج المثال السابق تم عرض آسم الموظف وراتبه وعمولته وباقي قسمة راتبه على ما يآخذه من عمولة . 


Date Functions : ارخ‎ JI 


هي دوال تتعامل مع البيانات التي من النوع ( تاريخ ٠)‏ وما للتاريخ والوقت من أهمية بالغة 2 الحياة 
اليومية بل إنه يمثل الحياة فقد قامت أوراكل بتوفير دوال بسيطة وقوية للتعامل مع التاريخ » علما بن 
أآوراكل قامت بتخزين التاريخ بالشكل التالي )02-M0۸-۷۷(‏ ڪما يمڪن تغيير هذا الشڪل عن 
طريق دوال آخرى تسمى دوال التحويل والتي سوف ندرسها بالتفصيل لاحقا » والجدول التالي يبين جميع 
دوال التاريخ ووظيفة ڪل منها . 


FUNCTION 4ألıلiا‎ 


دالة تستخدم لعرض تاريخ النظام الموجود بجهاز الحاسب الآلي ( تاريخ SYSDATE‏ 


اليوم الحالي ) 
دالة لاإيجاد عدد الأشهر بين تاريخبن 


دالة لإضافة عدد معين من الأشهر على تاريخ معطى 


دالة لإيجاد آخر يوم 2 الشهر لتاريخ معطى 


أل تىت 2 الا ل أ e‏ 
ااا ا و ي TRUNC(date)‏ 


0 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


کے 


تم إيجاد عدد الأشهر بين 


MONTHS BETWEEN(01-SEP-95','11-JAN-94) 19.6774194 
التاريخبن المعطيين‎ 

تم إضافة 1 آشهر على التاريخ 
المعطى 

إيجاد تاريخ يوم الجمعة بعد 
التاريخ '01-SEP-95'‏ 


إیجاد آخر یوم ے شھر سبتمیر ‏ ۲95م 30-9 LAST_DAY( 01-SEP-95")‏ 
September‏ 


تم تقريب التاريخ المعطى إلى 
آقرب شهر وبما آن اليوم هو ۲٠‏ 
آي آأكبر من ٠١‏ فتم التقريب 
إلى آول الشهر الذي يليه 

تم تقريب التاريخ المعطى إلى 
آقرب سنة وبما آن شهر 
(¥ا0 هو شهر (۷) فانه ته 
التقريب إلى آول السنة التالية 


ADD_MONTHS(11-JAN-94' , 6) '11-JUL-94' 


NEXT DAY(“01-SEP-95' , 'FRIDAY'") '08-SEP-95' 


ROUND(25-JUL-95' , 'MONTH') 01-AUG-95 


ROUND(25-JUL-95' , 'YEAR') 01-JAN-9606 


تم قص التاريخ المعطى بدون 
TRUNC(25-JUL-95' , 'MONTH)’) '01-JUL-95'‏ 
تقریب إلى آول يوم ج الشهر 


تم قص التاريخ المعطى بدون 
TRUNC(25-JUL-95' , 'YEAR') '01-JAN-95'‏ 
تقريب إلى آول السنة الحالية 


تذكر أن شهور السنة الميلادية هى : 


(ینایر - فبرایر - مارس - آبريل - مايو - پونيو - پوليو - آغسطس - سبتمبر - آڪتوبر - نوفمبر ¬ ديسمبر ) 
(JANURY-FEBRUARY-MARCH-APRIL-MAY-JUNE-JULY-AUGUST-SEPTEMBER-OCTOBER-‏ 
NOVEMBER-DECEMBER)‏ 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


يعض الأمثلة على دوال التاريخ : 


مثال (۷) : 


SQL> SELECT SYSDATE FROM DUAL; 


SYSDATE 


25-01-2004 


EEOC EEE ETE ELE OEE OEE OOO OO OOO OE OO OD O OO O O O O OOD OD O O OO O O O O O O O O OO OO GR O GO O O OO GR O GDR GGG 


NEE NEA Ea NS 
. تعمل عليه الآن‎ 


مثال (۸) : 


SQL> SELECT empno, hiredate , MONTHS BETWEEN(sysdate,hiredate) 
2 FROM emp 
3 WHERE hiredate like '% 1987" ; 


ج المثال السابق تم عرض رقم الموظفين وتاريخ تعيينهم وعدد الشهور بين تاريخ تعيينهم وتاريخ اليوم 
آي عدد الشهور التي فقضوها ج العمل ( نلاحظ أن علدد الأشهر عبارة عن أرقام عشربة ويمكن تقريبها 
باستخدام الدالة الرقمية ۸00۸2 كالآتى : 


SQL> SELECT empno, hiredate , ROUND(MONTHS BETWEENGsysdate,hiredate)) 
2 FROM emp 
3 WHERE hiredate like '% 1987" ; 


- °1 - 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


: )٩( مثال‎ 


SQL>SELECT empno,hiredate, ADD _IMONTHS(HIREDATE,6), LAST DAY(HIREDATE) 


2 FROM emp 
3 WHERE hiredate like '% 1987" ; 


2 المثال السابق تم عرض رقم الموظفين وتاريخ تعيينهم › وتاريخ التعيين بعد إضافة (1) آأشهر 
عليه » وآخر يوم 4 الشهر لتاريخ تعيينهم . 


: )۱١( مثال‎ 


SQL> SELECT empno,hiredate,N EXT DAY (hiredate,' FRIDAY") 
2 FROM emp 
3 WHERE hiredate like '%1987' ; 


7788 | 19-04-7 24-04-7 
7876 | 23-05-7 29-05-7 


ج المثال السابق تم عرض رقم الموظفين وتاريخ تعيينهم › وتاريخ آول يوم يوافق الجمعة بعد تاريخ 


- ° 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


کے 
دواJ‏ اgzilڍJ‏ : Conversion Functions‏ 
يوجد آنواع كثيرة من البیانات(٤۴‏ ۲ ۲ 0(4۸1۸41) يمكن تخزينها داخل الجداول ومن آهمها بيانات 
رقمية )N (M6 ٤R(‏ وبیانات حرفیة(R٤ C14۸۸ ٣-1‏ ) وبیانات التاریخ (0۸1۳() . ودوال التحویل تقوم 
بتحويل البيانات من نوع إلى آخر » وهي عبارة عن ثلاثة أنواع والجدول التالي يبين هذه الأنواع ووظيفة 
ڪل منها : 


FUNCTION %4ألıلıا‎ 


TO_CHAR(DATE/NUMBER ,'fmt’) 


تستخدم هذه الدالة لتحويل البيانات الرقمية أو بيانات التاريخ إلى 


تستخدم لتحويل البيانات الحرفية إلى بيانات من نوع التاريخ 
بشكل معین (1 M4۸‏ ۴0۸) حسب الطلب ٤٩؟‏ . 

تستخدم لتحويل البيانات الحرفية إلى بيانات رقمية بشكل معين 
)۴0RMA 1)‏ حسب الطلب ٥گ‏ . 


TO_DATE(CHAR , 'fmt') 


TO_NUMBER(CHAR , 'fmt') 


وا لہده الدوال من أهمية بالغة 2 عملية تحويل البيانات من نوع ای آخر فسوف نقوم بدرأاسة هده 
الوا ك واا عل د 


دالة التحويل _C٤۸R‏ 10 . 
أ ادا هده اال تول نات الا ج 0418 ال اتات رة 
اك اا 


TOۆ_CHAR(DATE‎ , 'fmt') 


E 


تقوم هذه الدالة بتحویل بیانات التاريخ الت بیانات حرهفية بشڪل معاںل یبسمی format‏ ويعبر عله 


بالجزء 1106 . والمثال التالى يوضح كيفية استخدامها . 


o۳ - 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


: )۱١( مثال‎ 


SQL> SELECT sysdate, TO CHAR(GSysdate,'DD/MM/YYY Y') 
2 FROM dual; ا ج‎ 


شڪل التاريخ بعد تحويلa FORM4A1‏ التاريخ المراد تحويله إلى بيانات حرفية 


SYSDATE TO CHAR(SYADTE,'DD/MM/YY YY’) 


26-01-2004 26/01/2004 


e: 
aT 


E EEE CI ONE 
ردا فرکن ار نظام جت ر‎ DMD a o ااك‎ 
. ) MM/Y ۷Y ¥( التالى‎ ۴0۸ M۸1 الشهر والسنة فقط » نكتب الشكل‎ 

ا a E‏ و ا و 
ENIS FOE las ORT a‏ 
يظهر التاريخ بالش كل (01/2004 0۴ 26) نقوم بكتابة الشکل ۴0۸۷/۸1 كالتالى : 
(DD "OF" MM/YYYY)‏ . 


الجدول التالي يوضح بعض الأشكال التي يمكن استخدامها عند تحويل التاريخ إلى بيانات حرفية 
إظهار السنة كاملة بالأرقام ( القرن + السنة ) مثل 2004 . 
إظهار السنة كاملة كتاب:R0‏ ١ا W0 11008۸ ND F۴٥١‏ ]ا ) وحالة حرف 
الكتابة تتوقف على حالة حرف كلمة ۷Y ٤4‏ . 


إظهار الشھرے شكل رقمين 01 .. 


إظهار الشهر كتابة (¥0Rا3۸N)‏ . 


اھان الت FRIDAY) i a‏ 
إظهار الوفت نظام ا( ساغة وهل هو هاا امنا °7 04:30:50) 


- 04 - 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


مثال (۱۲) : 


SQL> SELECT empno,TO_ CHAR(hiredate,'DAY "OF" MONTH YYYY HH12:MI:SS AM") 
2 FROM emp 
3 WHERE ename=upper(' king!) ; 


EMPNO | TO CHAR(HIREDATE,'DAY "OF" MONTH YYYY HH12:MI:S5S AM") 


7839 | TUESDAY OF NOVEMBER 1981 12:00:00 AM 


ج المثال السابق تم عرض رقم الموظف K]N6‏ وتاريخ تعيينه بشكل خاص » لاحظ وتآمل هذا 
الشكل 


دالة التحويل ۸Rګ0_C٥0†‏ . 


ثانيا : استخدم هذه الدالة لتحويل البيانات الرقمية 8۴۸ NUM‏ إلى بيانات حرفية . 
ا 


TOڙ_CHAR(NUMBER‎ , 'fmt') 


تقوم هده الدالة بتحويل البيانات الرفمية ا بیانات حرفية بشڪل معن يسمیى 10۲102 ويعبر 


وك المثال التالي نقوم بعرض آرقام الموظفين ورواتبهم الذين يآخذون رواتب آڪبر من ٥۰۰‏ دولار 
ل ا کو ا ا و و ی د 000 ل ن 3000 


- 00 _ 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


SQL> SELECT empno,TO_CHAR(SaI , '$99,999'") salary 
2 FROM emp 
3 WHERE sal > 2500 ; 


ê r SEC 


- °٦ - 


تقنية الجاسب الآلي ۱ حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


س کے 


. TO_DATE Jgحتلl‎ ةllد‎ 


الشكل العام : 


TO_DATE(CHAR , 'fmt’) 


بشکل معین یسمی 10۲۱۱۵ ويعبر عله بالجزء fmt‏ 1 


والمثال التالي يوضح كيفية استخدامها . 


: )۱٤( مٹال‎ 


SQL> SELECT TO_DATE('FEBRUARY 22, 1981', 'MONTH DD, YYYY') 
2 FROM dual 


TO DATE( FEBRUARY 22, 1981','MONTH DD, YYYY') 


22-FEB-1981 


ا اسان ت رل العانات اجرد 150617 22 186۸02 وال ورعن تارمان 
NEE EEE‏ 
E O E‏ 


- 0N 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


. TO_NUMBER Jıgحتلlا دة‎ 


TO_NUMBER(CHAR , 'fmt') 


تستخدم هذه الدالة لتحويل البيانات الحرفية التي تعبر عن رفم إلى بيانات رقnمية NUMBER‏ 
بشڪل معن يسمی 10۲103 ويعبر عنه بالجزء )۴00 . 

مثلا إذا كان لدينا عمود وصفت بياناته حرفية داخل جدول ومسجل به بيانات رقمية ونريد إجراء 
عمليات حسابية على هذا العمود هنا لابد من استخدام هذه الدالة لتحويل البيانات داخل العمود إلى 


بيانات رفمية . 


- ° - 


تقنية الجاسب الآلي ۱ حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


أسنلة الفصل الرابع 


عدد الأحرف المكونة للاسم » و عرض جزء من الاسم مبتدئ بالحرف الأول وحتى الحرف الرابع ؟ 
بحيث تظهر النتيجة كالتالى : 


EMP NAME NUMBER | SECTION 


Smıith 
Allen 
Ward 
Jones 
Martin 
Blake 
Clark 
Scott 
King 
Turner 
Adams 
James 
Ford 
Mıller 


ST 4 UO UO CT دا‎ O) U۸) ۸ VC U بډ‎ O ہی‎ 


۲ - اأكتب جملة استعلام لعرض آسماء ووظائف الموظفين بحيث تظهر كڪعمود واحد وذلك لموظفي 
الادارة رفم (30) © بحيث تظهر النتيجة كڪالتالى : 


ALLENSALESMAN 
WARDSALESMAN 


MARTINSALESMAN 
BLAKEMANAGER 
TURNERSALESMAN 
JAMESCLERK 


- 0۹ 


تقنية الجاسب الآلي حاب الفصل الرابع 
الرمجيات مقدمة قواعد بيانات أوراكل دوال الصف الواحد 


NUMBER OF YEAR 


MARTIN 
BLAKE 
CLARK 
SCOTT 
KING 
TURNER 
ADAMS 
JAMES 
FORD 
MILLER 


: اكتب جملة استعلام لعرض تاريخ اليوم ؟ بحيث تظهر النتيجة كالتالي‎ ٤ 


SATURDAY OF 02 / 2004 04:28 


۵- اكتب جملة استعلام لتحويل السلسلة الحرفية التالية إلى تاريخ 3 بحيث تظهر النتيحة 
كالتالى : 
lıdudilة‏ )2004 ,22 (FEBRUARY‏ . 


MY DATE 


22/02/2004 


مقدمة فواعد بيانات أوراكل 
الدوال التجميعية 


frmBmı [Code] 


End Sub 


1 Len (rallsg) . Û 7 ek Projectl - 


Ea 


ftrmMDI1,stsStatusfar, i 2 


aereên, ousePointer 


NEL 
If tPausêflagf The 


Else 


he. AS UT OT 


z2 Fh E] ھک‎ @ ¢ 


CRIPT larguage="davaSeript"> 


#/# Initialize effect 


" hî ql 1 


1 


fnull1l==el]l.eEffECTE] FEl.EffECTE = 


iHSZLEion animateAnChor ll { 
WAE P]l=eTeENLE.SEFECE lerment; 


IF ("A"' ==]. TtaqMame | 
1E 


تقنية الحاسب الآلي ۱ حاب الفصل الخامس 


البرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 
الدوال التجميعية لأكثر من صف 
GROUP FUNCTIONS‏ 
الجدارة : 


الأهداف : 
ENE E DALE‏ 
١‏ -فهم ومعرفة الدوال التجميعية لآأكثر من صف Group Functi0¬Ss‏ . 
۲ -معرفة آنواع الدوال التجميعية لآأكثر من صف Group Functi0¬s‏ . 
۲ -إنشاء المجموعات من البيانات باستخدام الجزء +8 ۴ ü٥١‏ . 
HAVRE a N Nl RES a‏ 


مستوى الأداء المطلوب : 
آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 


الوقت المتوقع للتدريب :+ آربع ساعات 


الوسائل المساعدة : 
6 فلم . 
9 

متطلبات الجدارة : 


E 


تقنية الجاسب الآلي ۱۱ حاب الفصل الخامس 
الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 


سک کے 


الفصل الخامس : مقدمة 


الدوال التجميعية لأڪثر من صف والتی تسمی N٥0110×85(‏ ۴0 00۶ 6۸) هي دوال تتعامل مح 
بيانات مجموعة من الصفوف لآخراج قيمة وأاحدة ا إذا آردنا إيجاد مجموع ما يآخذه الموظد 
م وات ف و ی کل ا ی ا ا ی و ا 0 0 
الدالة تقوم بعملية جمع للرواتب وتكون نتيجتها قيمة واحدة فقط وهي المجموع 

والشكل التالي يوضح كيفية عمل الدالة التجميعية 80١‏ . 


MARTIN 
BLAKE 


CLARK SQL > SELECT SUM(SAL) 

SCOTT FROM EMP; 205 
KING 

TURNER 

ADAMS 

JAMES 

FORD 


MILLER 


ڪما هو واضح من الشڪل آن الداlة S UM‏ ا 
وهي (29025) › وبالمثل عندما دريد ايجاد آڪبر راتب من يبن رواتب ب الموظفين فهناكک أيضا ذالة شن 
aE e O E‏ 
واحدة فقط . 


E 


تقنية الجاسب الآلي ۱۱ حاب الفصل الخامس 
الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 


أنواع الدوال التجميعية : Type of Group Functions‏ 
الجدول التالي يبين آنواع الدوال التجميعية ووظيفة كل دالة : 
وظفة 


دالة تستخدم لإيجاد أكبر قيمة من بين مجموعة من القيم 


دالة تستخدم لإيجاد آقل قيمة من بين مجموعة من القيم 


دالة تستخدم لإيجاد عدد القيم آو عدد الصفوف وهذه الدالة 

E 
EET 
E OT TT ET TOT 


وجميع هذه الدوال تتجاهل القيم الفارغة N11‏ داخل الأعمدة . 


أمثلة على الدوال التجميعية . 
مثال (۱) : 


SQL> SELECT SUM(Sal) , MAX(sal) , MIN(sal) , AVG(sSal) 
2 FROM emp ; 


SUM(SAL) | MAX(SAL) | MIN(SAL) | AVG(SAL) 


29025 5000 24033.249 


ج المثال السابق تم عرض مجموع رواتب الموظفين وأكبر راتب وآقل راتب والمتوسط الحسابي 
للرواتب . 
lees AE MINS MAS NESE DS‏ 
البيانات الحرفية تكون النتيجة حسب الترتب الأبجدي . لاحظ المثال التالي . 


= 


تقنية الحاسب الآلي ۱ حاب الفصل الخامس 
وراکل الدوال التجميعية 


C+ 


الرمجيات مقدمة قواعد بيانا 


SQL> SELECT MAX(ename) , MIN(ename) 
2 FROM emp ; 


MAX(ENAME) Î MIN(ENAME) 


مٹال (۳) : 


SQL> SELECT AVG( NV L(comm , 0) ) 
2 FROM emp ; 


AVG( NVL(comm , 0) ) 


157.14286 


2 المثال السابق تم عرض المتوسط الحسابي لمكافآت الموظفين » ونلاحظ استخدام الدالة N71‏ 
هنا لحل مشكلة القيم الفارغة N01]‏ الموجودة داخل العمود ٥01١1١‏ وذلك لأن المتوسط الحسابي 
عبارة عن مجموع القيم مقسومة على عدد الموظفين وبما آن الدوال التجميعية تتجاهل القيم الفارغة فڪان 
ن ت ااه على عد وطن وه 147 موقا . 

إذا لم نستخدم الدالة N۷1‏ فسوف يتم E E EE‏ من (14) وبالتالي ييڪون 
المتوسط الحسابي خطا كما هو واضح كالتالي : 


SQL> SELECT AVG( comm ) 
2 FROM emp ; 


المتوسط الحسابى هنا خطا لأنه تم القسمة على ) AVG( comm‏ 


EEE ga GEESE SÎ 


E 


تقنية الجاسب الآلي ۱۱ حاب الفصل الخامس 
الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 


التعامل مع الدالة 01ا0 . 


: هما‎ C011 يوجد حالتان للدالة‎ 
e COUNT(*). 
e COUNT(column) . 


تستخدم الدالة (011)7 لعد جميع الصفوف داخل الجدول بما فيها الصفوف المكررة والصفوف 
التي تحتوي على القيم الفارغة N01]‏ » وإذا كانت جملة الاستفسار تحتوي على شرط W٤۲۶‏ 
فإنها تقوم بعد الصفوف حسب جملة الشرط . 
۵ تستخدم الدالة C0111)٥010070(‏ لعد قیم آو بیانات عمود معین مع تجاھل القیم NU1|1‏ . 
والأمثلة التالية توضح ذلك . 


: )٤( مثال‎ 


SQL> SELECT COUNT(*),COUNT(comm), COUNT(deptno) 
2 FROM emp ; 


COUNT(E) | COUNT(COMM) | COUNT(DEPTNO) 


تم عرض إجمالي عدد الصفوف داخل جدول الموظفين وهم 14 صفا » وأيضا تم عرض الموظفين 
الذين يآخذون مكافآت وعددهم داخل الجدول (4) » نلاحظ هنا أن الدالة (010۳ء) C00 N1‏ قد 
تجاهلت القيم الفارغة N0]‏ داخل العمود 00١MM‏ . كما تم عرض عدد الإدارات داخل العمود 
0 وهم (14) بالرغم من أنها مكررة داخل العمود آي إن الدالة [N1‏ 0ا00 تقوم بعد القيم المكررة . 


: )٥( مثال‎ 


SQL> SELECT COUNT(comm) , COUNT() 
2 FROM emp 
3 WHERE deptno=30 ; 


COUNT(COMM) COUNT) 


0 


۱ حاب الفصل الخامس 


مقدمة قواعد بيانات أوراكل الدوال التجميعية 
ج المثال السابق تم عرض عدد الموظفبن الذين يآخذون عمولة 2 الإدارة رقم 30 وكان عددهم آربعة بينما 
كان إجمالى عدد الموظفبن 2 الادارة هو ستة موظفبن . 


إنشاء مجموعات من البيانات ياستخدام الچِزء GROUP BY‏ :+ 
No I ESN gE E‏ 
ا ی ی ا 
ذلك نستخدم الجزء 8¥ 6۸00۴ والذي يقوم بتقسيم البیانات إلى مجموعات على حسب عمود معين أو 
آڪٽر . 
والشكل التالي يبين تآثير استخدام الجزء 0y‏ ۲0ع . 
SQL >SELECT deptno , MAX(sal)‏ 


2 FROM emp 
3 GROUP BY deptno ; 


DEPTNO MAX(SAL) 


من الشكل السابق يتضح آنه تم تقسيم الموظفين إلى مجموعات حسب رقم الإدارة وكان آكڪبر 
راتب 2 الإدارة رقم 10 هو (5000) وآأكبرراتب 2 الإدارة رقم 20 هو (3000) A‏ آآڪبر راتب 2 
الادارة رفم ۰ هو (2850) : 


E 


تقنية الحاسب الآلي ۱ حاب الفصل الخامس 


الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 
مثال (1) : 


SQL> SELECT deptno , AVG(Sal) 
2 FROM emp 
3 GROUP BY deptno 
4 ORDER BY AVG(SaD) ; 


DEPTNO AVG(SAL) 


7 1 
215 
0۰7 233ص 


E N E ENE cE E E E 


ملحظات على استخدام الدوال التجميعية : 
۵ عند كتابة أي عمود داخل قائمة 581٤٥1‏ لابد من كتابته مع الجزء 8 6۸00۴ وذلك لأن 
الدوال التجميعية تتعامل مع عدة صفوف . 
۵ يمڪن استخدام الجزء 8۷ 0۸۴۴ لترتب الصفوف مع الدوال التجميعية كما هو مبين 2 
المثال السابق . 
١‏ لا يمكن استخدام الدوال التجميعية 2 الجزء ۴ W8 ٤R‏ ولڪن نستخدم ائلجj« HAVING‏ 
a‏ 


عند تنفيذ هذا المثال تم إعطاء رسالة خطا وذلك لأننا كتبنا أسم SQL> SELECT deptno , AVG(sal)‏ 


Z2 FROM emp aT e 
ولم نكتبه ضمن الجزء‎ 8616٥٤ ضمن قائمة‎ ) 10 | 
3 ORDER BY AVG(saD) ; ۰ ا‎ )4ep٤٣0( لعمود‎ 


9 


رط 0upاع‏ ولتصحيح هذا الخطا انظر المثال رقم (1) . 


ERROR at line 1 : 


ORA-00937: not a single-group group function 


UV 


تقنية الجاسب الآلي ۱۱ حاب الفصل الخامس 
الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 


SQL> SELECT deptno , AVG(Sal) 
2 FROM emp 


3 WHERE AVG(Sal) > 2000 
4 GROUP BY deptno ; 


ERROR at line 3 : 
ORA-00934: group function is not allowed here qq رسالة خط‎ 


عند تنفين المثال السابق تظهر رسالة خطاً » وذلك لآننا استخدمنا الدالة (6)631 ۸۷ داخل الجزء 
شرط خاصة بالدوال التجميعية وهي 8۸۷1١6‏ كما 2 المثال رقم () : 


: )٩( مثال‎ 


SQL> SELECT deptno , AVG(sal) 
2 FROM emp 
3 GROUP BY deptno 
4 HAVING AVG(Sal) > 2000 ; 


DEPTNO AVG(SAL) 


2916.66667 
E 


ے2 هذا المثال تم عرض المتوسط الحسابي لمرتبات الموظفين 2 كل إدارة بشرط آن تكون 
a LTA VIRNCO LEN OOD Sa E EEN CLS EEA‏ 
a OEE‏ 


يمكن استخدام جميع أجزاء جملة S£18٣1‏ بشرط مراعاة الملاحظات السابقة عند الاستخدام . 
E‏ 


- 1۸ - 


تقنية الجاسب الآلي ۱ حاب الفصل الخامس 
مقدمة قواعد بيانات أوراكل الدوال التجميعية 


SQL> SELECT job , SUM(sal) 
FROM emp 


WHERE job not like 'SALES%o' 
GROUP BY job 


HAVING SUM(sal) >5000 


ORDER BY SUM(salD ; 


SUM(SAL) 


ANALYST 6000 
MANAGER 8215 


E E CBS E E N NY 


0۹ 


تقنية الجاسب الآلي حاب الفصل الخامس 
الرمجيات مقدمة قواعد بيانات أوراكل الدوال التجميعية 


کے 
أسنلة الفصل الخامس 


MAXIMUM MINIMUM 


۲ - اڪتب جملة استعلام لعرض آسماء الوظائف وآعلى وآقل راتب لہده الوظائف كل على حده ۹ 
بحيث تظهر النتيجة كالتالي : 


MAXIMUM MINIMUM 


ANALYST 
CLERK 
MANAGER 
PRESIDENT 
SALESMAN 


۲ - اكتب جملة استعلام لعرض الوظائف وعدد الموظفين 4 كل وظيفة © بحيث تظهر النتيجة 
كالتالى : 


هھ 


COUNT) 


ANALYST 
CLERK 
MANAGER 
PRESIDENT 
SALESMAN 


: اكتب جملة استعلام لعرض عدد المديرين 3 بحيث تظهر النتيجة كالتالي‎ - ٤ 


NUMBER OF MANAGERS 


مقدمة فواعد بيانات أوراكل 


عرض البيانات من آڪٹر من جدول 


1 Len (rallsg) = 7 The Project ِ frmB mi [Code] 5 
Screen, HousePointer o 


i FE 2ub ALalt | 
trmMDI.stsStat usPar, Fé E e 8 eT 
Else | 


If tPausêflagf The 
frmID1. staStatuafar, Pan 
Elğ3Ee 


End Sub 


4E HT OTT | 


EHH £4 O 4 HEA o 


CRIPT language="JavaStE ipt"s 


iHSZLEion animateAnChor ll { 
WAE E]=eTERT,.SECE lermeEent ; 
if ("A"==e1].tagName} { #/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


عرض البيانات من أكثر من جدول 


DISPLAYING DATA FROM MULTIPLE TABLES 


: الجدارة‎ 
OEE E e 
: الأهداف‎ 


عندما يكتمل هذا الفصل يكون لديك القدرة على : 
١‏ -فهم كيفية عرض البيانات من آأكثر من جدول ومفهوم ربط الجداول . 
۲ -معرفة الآنواع المختلفة لربط جدولين أو أكثر . 
٣‏ -معرفة واستخدام الربط بالتساوي بين الجداول ۴٩u] 01١‏ . 
٤‏ -معرفة واستخدام الربط بعدم التساوي بين الجداول N01-٤٩۷1[011‏ . 
۵ -معرفة واستخدام الربط الخارجي بين الجداول 010[ 6۲ا0 . 


ر ر 
مستوى الأداء المطلوب : 


أن يصل المتدرب إلى إتقان هذه الجدارة 1/٠٠١‏ . 
الوقت المتوقع للتدريب + أربع ساعات 
الوسائل المساعدة : 


© فلم . 
۵ دفتر. 
متطلبات الجدارة : 


SN 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 


البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 
الفصل السادس : مقدمة 


4 بعض الأحيان نذريد أن نقوم بعرض بيانات من أكثر من جدول لعمل تقارير مفيدة 
وشاملة « فمٹلا لو آردنا عرص رفم الموظف ورفقم الادارة التابع لہا وموفع هذه الادارة دحد أذنا لان من 
الحصول على هذه البيانات من جدول الموظفين وجدول الإدارات لكون رقم الموظف موجود 4 جدول 
الموظفين ورقم الإدارة موجود ب4 جدول الإدارات وأيضا موجود ب4 جدول الموظفين بينما موقع الإدارة 


EMP table DEPT table 


El E 
ES ESE 
IRADE IRA DHA 


El: E 
EE E E 


ا 4 ا ا 
TEETER TERT EE TEER ERT ERE‏ 


E 


DEPTNO 


البيانات المراد الحصول NEW YORK‏ 


DALLAS 
CHICAGO عليها من الجدولين‎ 


BOSTON 


E O E OE E EE E a a E, 
EERE TEE ERT ERENT ENTER TERT E TETER ETE TERE 


وللحصول على تلك البيانات لابد من عمل ربط بين الجدولين . وسوف نقوم 2 هذا الفصل بشرح 
أنواع الربط المختلفة وكيفية عمل كل نوع من هذه الأنواع . 


نعريف اأريط : Join defination‏ 
هو عبارة عن ربط بين جدولين آو أكثر للحصول على بيانات من تلك الجداول . 


INT 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


أنواغ الربط : Types of Joins‏ 
توجد عدة آنواع من الربط )[01١5(‏ وهي كالتالي : 
" الربط بالتساوي 1 ۴٩u‏ . 
" الربط بعدم التساوي Non-EqU1]01¬‏ . 
* الربط الخارجي Outer Join‏ . 
" الربط الداخلي ے نفس الجدول [01١‏ ام8 . 


. WIERE LN ly, SEE aaa sj غ‎ sz عمل ها اا‎ 


الربط بالتساوي : o1١‏ إEJui‏ 


2 هذا النوع من الربط يتم ربط جدولين أو أكثر عن طريق عمودين متساويين › العمود الأول عادة 
ما يڪون مفتاح آساس (۷ءK‏ ر٣دة٣!۴۲)‏ 2 الجدول الأول والعمود الثاني يكون عبارة عن عمود ربط 
)Foreıgn Key)‏ 4 الجدول الثاني . 

والشكل التالي يبين الربط بالتساوي بين جدول الموظفين وجدول الإدارات عن طريق العمود 
(0٣اpعل)‏ الموجود 2 ڪل منهم . 


EMP table DEPT table 


7566 | JONES | MANAGER OPRATIONS BOSTON 


Foreign Key Primary Key 


aad CE e EO E 
بالسهم كما ك المثال التالي‎ 


INE 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


ج و و و و و و و و و و و و 0 


مثال (۱) : 


SQL> SELECT emp.empno , emp.ename , emp.deptno , 
2 dept.deptno , dept.loc 1 
3 FROM emp , dept شرط الربط بين الجدولين ر‎ 
4 WHERE emp.deptno=dept.deptno ; 


DEPTNO 


DALLAS 
CHICAGO 
CHICAGO 
DALLAS 
MARTIN CHICAGO 
BLAKE CHICAGO 
CLARK NEW YORK 
SCOTT DALLAS 
KING NEW YORK 
TURNER CHICAGO 
ADAMS DALLAS 


ے لقال السابق تم عرض بيانات من جدولين عن طريق الربط بالتساوى » وسوف تقوم شرح كل 
SE as. SEDI CTS aa‏ 


ے قائمة ۴01 5٤]‏ تم عرض رقم الموظفين وأسمائهم وآرقام إداراتهم من جدول الموظفين 
)٤EMP(‏ » كما تم عرض رقم الإدارات وموقعها من جدول الإدارات )0٤۲1(‏ » ونلاحظ هنا آننا 
ea sa lal E‏ 
العلامة (.) كالتالي p10(‏ 0ء . (emp‏ . 

ه 2 الجزء ۴۸0M‏ تم كتابة أسماء الجداول التي ستأتي منها البيانات كالتالي 
(FROM emp,dept )‏ . 

E A Sb as Eg E E WES 


الربيط » ويدون هذا الشرط سوف تڪون النتيجة ليس لہا معنى آو فائدة : 


-_ V0 -_ 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


أ" ستخدام الاسماء المستعارة للجداول : 


Ela Sa E a a 
: آسم الجدول (۳Pء) بالحرف (۴) » وآسم الجدول (أ۴) بالحرف (ل) كالتالي‎ 


SQL> SELECT e.empno , e.ename , e.deptno , 
2 d.deptno , d.loc 
3 FROM emp e, dept d 
4 WHERE e.deptno=d.deptno ; 


O E A E 


عندما نريد عرض البيانات الموجودة ج المثال رقم )١(‏ ولكن للموظف K]N6‏ فقط فإنتا هنا لابد 
من زيادة شرط على جملة SE] ۴٤٣1‏ کالتالی : 


مٹال (۲) : 


SQL> SELECT e.empno , e.ename , e.deptno , 
2 d.deptno , d.loc 
3 FROMemp e, dept dq. (€ , @ الاسماءالمستعارة‎ 
4 WHERE e.deptno=d.deptno 
5 AND e.ename = upper('king') ; 


EMPNO | ENAME DEPTNO DEPTNO | LOC 


7839 | KING NEW YORK 


e 


N 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


الريط يعدم الiسlوي‏ : Non-Equijoin‏ 


LIE kyo E E 
لا نستخدم فيه علامة التساوي (=) » ولكن لابد من وجود علاقة غير مباشرة مثل شرط معين ينطبق‎ 
عليهما » مثلا عندنا جدول الموظفين وفيه عمود الراتب ([54) وأيضا لدينا جدول آخر يسمى جدول‎ 
هذا الجدول يتم وضع فتثات للرواتب وكل فة تتحصر بين آعلى راتب وآقل‎ 2 )54[-6R۸42٤( الفئات‎ 
ف ت ای ر 0000 ا رک کا هو اک فن درل الات ادا‎ 
وبذلك نجد أن هناك علاقة بين الجدولين وهي آن كل راتب 4 جدول الموظفين لابد أن يتبع فة معينة‎ 
. داخل الجدول (8416۸428) أي إنه يقع بين أعلى قيمة وأقل قيمة داخل الجدول‎ 


والشكل التالي يوضح جدول الموظفين N۶‏ وجدول الفئات 59۸416۸40٤‏ والعلاقة بينهم . 


EMP table SALGRADE table 


MARTIN 


راتب من رواتب الموظفين والتي 
حصلنا عليها من الجدولين 


2 
E E E EEE E E E E E E E E E E E E E EE E EEE E EE 


. Non-Equ1ijoin 


NV 


تقنية الجاسب الآلي ۱ حاب الفصل السادس 
الارمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 
مثال (۲) : 
SQL> SELECT e.ename , e.sal , s.grade‏ 


2 FROM emp e , salgrade s 
3 WHERE e.sal BETWEEN s.losal AND s.hisal ; 


شرط الربط بین انجدوتن 


ENESCO NINE EPSTEIN IPED BIOSIS IPSN SIEITEITSETSITSSETIE EIDE IPSNIPEIPSNISINETBOIITETESEIPEIRIESITEROSSPIS 
E E E e E O O E E E E O E E A E E 


MARTIN 
MILLER 
ALLEN 
TURNER 
JONES 
BLAKE 
CLARK 


CE O E A A A E E E A 
E واا ا وا ا ا وا ا ی ا ا ی یا ا وا یا ا ا یا ا ا یا وا اا یا وا یا ا وا ا ی یا ا یو یا ا وا ا ا ا ی ا‎ 


4 المتال السابق تم عرض آسماء الموظفين ورواتبهم من جدول الموظفين وعرض الفئات لكل راتب 
من جدول الفثات وذلك عن طريق الربط بعدم التساوي بين الجدولين وتم ذلك 4 جزj«‏ الiشرفط WIHERE‏ 
alئڻs.h BETWEEN s.losal AND‏ اهء.ء والذي يوضح شرط انحصار رواتب الموظفين 4 جدول 
الموظفين بين آقل راتب وأكبر راتب 4 جدول الفئات . 


Outer Join : الربط الخارجي‎ 

E E las e CCA aS GG 
الرنط بالفمارى ( 066(0 بين افخدوئن ى اها مر مطاف تقرط الاي وة اة لانت ان‎ 
)+( تظهر » 4 هذه الحالة نقوم بالريط بين الجدولين باستخدام الربط بالتساوي ولكن نضيف الجزء‎ 
ا ا ا ا و ا ای 0 0 ا‎ 
توجد الإدارة رقم (40) ج جدول الإدارات ولكن لا يوجد بها موظفين مسجلين 4 جدول الوظائف عند‎ 
Rl Ee ENO a SC 
. ولأإظهارها لابد من استخدام الربط الخارجي‎ 


- VA - 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


المثال التالى يبين كيفية الريط ببن جدولبن باستخدام الربط الخارجى (01۸[ ١ء‏ uا0)‏ لإظهار 
كافة البيانات الموجودة بالجدولين سواء كانت البيانات المطابقة لشرط التساوي أو غيرالمطابقة لشرط 


: )٤( مثال‎ 


SQL> SELECT e.empno , e.ename , d.deptno , d.dname 
2 FROM emp e, dept d 
3 WHERE e.deptno(+)=d.deptno ; 


عاذت الريط الخارجن 


DEPTNO 


ACCOUNTING 
KING ACCOUNTING 
MILLER ACCOUNTING 
SMITH RESEARCH 
ADAMS RESEARCH 
FORD RESEARCH 
SCOTT RESEARCH 
JONES RESEARCH 
ALLEN SALES 
BLAKE SALES 
MARTIN SALES 
JAMES SALES 
TURNER SALES هذه الإدارة ظهرت لاستخدامنا‎ 
WARD SALES 

الربط الخارجي OPERATIONS‏ 


ے المثال السابق تم عرض آرقام الموظفين وآسمائهم من جدول الموظفبن كما تم عرض آرقام 
الإدارات وأسمائها من جدول الإدارات باستخدام الريط الخارجي (١1ه[‏ إ6اا0) ولذلك قد ظهرت الإدارة 
رقم (40) بالرغم آنها غير مطابقة لشرط التساوي آي لا يوجد بها موظفين مسجلين 4 جدول الموظفين . 


۷۹ 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


الربط الداخلي لنفس الجدول : ذ0ل ؟اء؟ 


ا 


E 


EE E 


EMP table 


_ 1839 | KING | PRESIDENT 


SE E 


EMP (WORKER) EMP (MANAGER) 


E 


ل 


2 


EEE 
EE 


BE A 


1 ی ا 


عندما ندقق ے2 جدول الموظفین نجد آنه يحتوي على عمود یسمی )M¥6R(‏ هذا العمود یمثل رقم 
المدير للموظف » فنجد أن الموظف )8146K٤(‏ مديره هو الموظف ذو الرقم (7839) آي إنه الموظف 
)K1N6(‏ » ومن ذلك يتضح لنا آن هناك علاقة بين عمود المدير )M6R(‏ ورقم النفموظف (EMPNO)‏ 
فالمدير هو نفسه عبارة عن موظف آي يوجد له رقم موظف داخل العمود (M۴۲[N0ع)‏ » آي إننا نستطيع 
ريط الجدول بنفسه عن طريق العمودينj )(EMPNO) وş (MGR)‏ . 


ولعمل هذا النوع من الربط لابد من تقسيم جدول الموظفين إلى جدولين أحدهما يمثل جدول 
الموظفىن ونسميه مثلاً )W0R۸)۴۸(‏ والآخر يمثل جدول المدراء ونسميه مثلاً )M۸N۸46۴8(‏ كماهو 


واضح من الشكل السابق » ونقوم بعد ذلك بربط الجدولين عن طريق الربط بالتساوي )۴٩۷1[01۸(‏ . 


والمثال التالى يوضح كيفية عمل الربط الداخلي لنفس الجدول . 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


کے 
مثال :)۵٥(‏ 


SQL> SELECT WORKER.empno , WORKER.ename , MANAGER.ename manager 
2 FROM emp worker „, emp manager 


3 HERE ker. 2 . 
WwW worker.mgr = manager.empno # و را نن ادو‎ 
MANAGER 


MARTIN 
BLAKE 
CLARK 
SCOTT 
TURNER 
ADAMS 
JAMES 
FORD 
MILLER 


ج المثال السابق تم عرض آرقام الموظفين وأسماتهم من جدول الموظفين(W0R)K۴R)‏ كما تم 
الجدول (011۸ل )Se[۴‏ . 


الربط بين أكثر من جدولين : 
لربط أكثر من جدولين لابد أن تتوفر علاقة ما بينهم جميعاً علما بأنه لابد أن تكون جمل الشرط 
لمستخدمة ب4 عملية الربط تساوي (عدد الجداول )١-‏ » أي إذا كان لدينا جدولان فلابد من أن هناك 
شرط واحد لربطهما » وإذا كان لدينا ثلاثة جداول فيجب آن يتوفر شرطان لربطهما وهكڪذا . ولابد من 
وضع المعامل )A[N((‏ بين هذه الشروط . 
المثال التالي يوضح كيفية ربط ثلاثة جداول معا لعرض بيانات من ڪل منهم . 


SAY 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


SQL> SELECT e.empno , e.ename , e.sal , d.dname , s.grade 
2 FROM emp e, dept d , salgrade s 1 
3 WHERE e.deptno=d.deptno رط الط بن جاول ااوطف وجول اودارا ۾‎ 


4 AND e.sal BETWEEN s.losal and s.hisal jag شرط الربط بين جدول الموظفبن‎ 


RESEARCH 
RESEARCH 
SALES 
SALES 
MARTIN SALES 
MILLER ACCOUNTING 
ALLEN SALES 
TURNER SALES 
JONES RESEARCH 
BLAKE SALES 
CLARK ACCOUNTING 
SCOTT RESEARCH 
FORD RESEARCH 
KING ACCOUNTING 


1 
1 
1 
94 
2 
2 
3 
3 
4 
4 
4 
4 
4 
5 


ك المثال السابق تم ربط ثلاثة جداول مع بعضها وهي جدول الموظفين )ENP(‏ وجدول الإدارات 
۲75 () وجدول الفکات )5S41L6G۸۸0٤(‏ وذلك لعرض آرقام الموظفىين وآسمائهم ورواتبهم وآسماء 


لاحظ آننا استخدمنا شر طن لربط ثلاثة حداول . 
شرطین لرد جداول 


- AY - 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 


البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


أسنلة الفصل السادس 


۹ س اڪتب جملة استعلام أعرض اها وآرقام ادارات وآسم الإدارات للموظفىين المسجلىن _2 الاإدارة رفم 


WARD 


MARTIN 
BLAKE 
TURNER 
JAMES 


۲ - اكتب جملة استعلام لعرض أسماء الوظائف ومكانها للموظفين المسجلين بالإدارة رقم (۳۰) مع 
E E aa‏ 


۳ اڪتب جملة استعلام لعرض اا2 ووظائف وأسماء الإدارات للموظفين المىجلىن بالادارة التي تفع 
2 مدينة (0۸[1458) $ بحيث تظهر النتيجة كالتالى : 


CLERK RESEARCH 
MANAGER | RESEARCH 
ANALYST ; RESEARCH 
CLERK RESEARCH 
ANALYST | RESEARCH 


ا اڪتب جملة استعلام أعرض آسماء ووظائف وآأسماء إدارات ورواتب وات الرواتب للموظفىين 
المىجلىن بالادارة رفم (10) ۶ بحيیث e‏ ڪالتالي ا 


- Ar - 


تقنية الحاسب الآلي ۱ حاب الفصل السادس 
البرمجيات مقدمة قواعد بيانات أوراكل عرض البيانات من أكثر من جدول 


المىىجلىن بالادارة رفم (10) ۶ بحيیث تظهر النتيجة ڪالتالى 


EMPNO | ENAME MANAGER _NO MANAGER _ NAME 


7782 | CLARK 7839 | KING 
7934 | MILLER 7782 | CLARK 


SANE 


مقدمة فواعد بيانات أوراكل 


الاستعلامات الفرعية 


frmBmıi [Code] 


ET SPO) Proiectl - fmBmi [Code] __ 
emacs ا‎ 


SCTE. Biioliiet E 
frmMDI.atsStatusfar, i 1 


NEL 
If tPausêflagf The 


Private aub cmALalc | 


End Sub 


Else 


ت ا ھک کد z2 Fh E]‏ 


CRIPT larguage="davaSeript"> 


iHSZLEion animateAnChor ll { 
WAE E]=eTERT,.SECE lermeEent ; 
IF ("A"' ==]. TtaqMame | 
iF Inull==el]l.effECTE] El.EffECTE = 


{ y#yj Initialize effect 
" hî ql 1 


تقنية الحاسب الآلي حاب الفصل السابع 


الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 
الاستعلامات الفر عيه 
SUBQUERIES‏ 
الجدارة : 


الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على : 
| -فهم متى وكيفية استخدام الاستعلامات الفرعية . 
۲ -معرهة أنواع الاستعلامات الفرعية . 
۳ -معرفة واستخدام الاستعلام الفرعي أحادي الصف ء51041 Sıngle-K 0W‏ . 
٤‏ -استخدام معاملات المقارنة ذات الصف الواحد مع الاستعلام الفرعي آحادي الصف . 
۵ -معرفة آماكن كتابة الاستعلامات الفرعية داخل جملة )٤eاع8‏ . 
-معرفة واستخدام الاستعلام الفرعي المتعدد انلصفaوف Multıple-Row SubqUery‏ 
-استخدام معاملات المقارنة المتعددة الصفوف مع الاستعلام الفرعي المتعدد الصفوف . 


گے > 


مستوى الأداء المطلوب : 

آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 
الوفت المتوقع للقدريب : آربع ساعات 
الوسائل المساعدة : 


فلم . 


8 دفتر. 
متطلبات الجدارة : 


- A٦ - 


تقنية الجاسب الآلي حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


الفصل السايع : مغدمة 


لمعرفة وفهم آهمية الاستعلامات الفرعية(5ء1۲1٩510)‏ آأجب عن هذا سؤال . 
من هم الموظفون الذين يأخذون رواتب أكبر من راتب الموظف (١ع١0ل)‏ ؟ 
الاخات غل هذا العوال لايد ارلا من معرة ما هومرك الف 0006 :ت خد هدا المرب 
E E‏ ر د ا ر ی رن روا کر راد اف 
الاستعلام الأول : إيجاد مرتب الموظف [0١٤5(‏ ) كالاآتي : 
SQL > SELECT sal‏ 


2 FROM emp 
3 WHERE ename = 'JONES' ; 


الاستعلام الثاني : استخدام ناتج الاستعلام الأول لمعرفة الموظفين الذين يآخذون رواتب أكبر من هذا 
الناتج كالاتى : 
SQL > SELECT ename‏ 


2 FROM emp 
3 WHERE sal > 2975 ; 


ENAME 


LE E a a 
Eo aE e E 
SQL > SELECT ename 


2 FROM emp 
3 WHERE sal > (SELECT sal FROM emp WHERE ename = 'JONES') ; 


- AV - 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


سسس کے 


الشكل العام لجملة الاستعلامات الفرعية : 


ج 
مجموعة الأعمدة اl.فلوiı SQL > SELEËÊCT‏ 

llجدJa FROM‏ 
ز (الجدول ۲0۳ مجموعة الأأعمدة المطلوبة عك ( معامJ‏ lاlقتlرii‏ llأږnڍد WHERE‏ 


الاستعلام الداخلي ( الفرعي ) 


مثال )١(‏ : عرض أرقام وأسماء ووظائف الموظفين الذين يعملون على نفس وظيفة الموظف ×۴ا ]۸ . 


SQL> SELECT empno , ename , job 


2 FROM emp 
3 WHERE job = ا‎ 


(select job 


from emp aS 
where ename = 'ALÛEN') م الداخلي (الفرعي‎ 


SALESMAN 
WARD SALESMAN 
MARTIN SALESMAN 


قال فاق ف اباد ورطع الرطت (5 418 آولا بعل اتلام دا خی (فرغی) وكانت 
)SALESM4(‏ عن طريق الاستعلام الخارجي (الرئيس) . 


ملحوظة هامة : يقوم أوراكل بتنفيذ الاستعلام الداخلي ( الفرعي ) ولا ثم ينفذ الاستعلام 


الخارجي (الرئيس) . 


- AA - 


تقنية الحاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل سے 
ر 
أنذواع الاستعلامات الفرعية : 
تنقسم الاستعلامات الفرعية إلى ثلاثة آنواع هي : 
# استعلام فرعي آحادي الصف ويرجع بصف |د Single-Row Subquery‏ . 
١‏ استعلام فرعي متعدد الصفوف ويرجع بآڪثر من صف Multıple-Row SubqUeIy‏ . 
١‏ استعلام فرعي متعدد الأعمدة ويرجع بأڪثر من eعanود Multiple -Column SubqUery‏ . 


متطلبات وإرشادات الاستعلام الفرعي : 


يجب مراعاة الآتي عند استخدام الاستعلام الفرعي . 

" يجب وضع الاستعلام الفرعي بين قوسين . 

" يجب وضع الاستعلام الفرعي يمين معامل المقارنة (<>ركر=< , ك> ..إلخ). 

" يجب التأكد من استخدام المعاملات الأحادية الصف مع الاستعلامات الفرعية الأحادية 
اl|صm (Single-Row Subquery)‏ . 

" يجب التأكد من استخدام المعاملات المتعددة الصفوف مع الاستعلامات الفرعية المتعددة 
انصAaè (Multiple-Row Subquery)‏ . 


أنواع معاملات المقارنة المستخدمة مع الاستعلام الفرعي : 
يوجد نوعان من معاملات المقارنة وهي : 
TO E N EE a a aE E‏ 
أحادية الصف آي التي ترجع بصف واحد (قيمة واحدة) . 
" معاملات متعددة الصف مثل ۸١۷ , 1N(‏ , []]4) وتستخدم مع الاستعلامات الفرعية متعددة 
الصفوف آي التي ترجع بآڪكثر من صف . 


أماكن كتابة الاستعلامات الفرعية داخل جملة {ءعاء؟ : 


+ SELECT ls ga e E aS N NE hM 
. (WHERE , HAVING , FROM) 


- A٩۹ ۔-‎ 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


الاستعلامات الفرعية الأحادية الصف : Single-Row Subqueries‏ 
وهي ااا ا كرون عا مف واه فد د م ا ا 


اا ي ا ج 


مثال (۲) : 
فم بعرض أسماء ورواتب وأرقام ادارات الموظفين الذين يعملون 2 نفس إدارة الموظف (KING)‏ %4 


SQL> SELECT ename , sal , deptno 
2 FROM emp 
3 WHERE deptno = 10 
( select deptno 
from emp 
where ename='KING' ) ; 


SAL j DEPTNO 


KING 
MILLER 


المثال السابق تم إيجاد رقم إدارة الموظف )K[N6(‏ آولا بعمل استعلام داخلي (فرعي) » ثم عرض 
أسماء ورواتب وأرقام إدارات الموظفين 2 الإدارة رقم (10) وهي إدارة الموظف )&]N6(‏ . 


مثال (۳) : 
قم بعرض أسماء ووظائف ورواتب الموظفين الذين رواتبهم مساوية لأقل راتب 5 


SQL> SELECT ename , job , sal 
2 FROM emp 800 
3 WHERE sal = 
( select MIN(sal) N 
from emp) ; 


تقنية الحاسب الآلي حاب الفصل السابع 


الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


: )٤( مثال‎ 


قم بعرض آرقام الإدارات وأقل راتب يأخذه موظف فيها بحيث يڪون آقل راتب فيها آڪبر من قل 
راتب 2 الإدارة رقم (20) ؟ 


SQL> SELECT deptno , MIN(sal) 
2 FROM emp 
3 GROUP BY deptno 800 


4 HAVING MIN(sal) > 
5 ( select MIN(sal) 


from emp 
where deptno = 20 ) ; 


DEPTNO Î MIN(SAL) 


2 المثال السابق تم استخدام الدالة التجميعية MN[N)S4[(‏ 2 الاستعلام الرئيس لذلك استخدمنا 
#86 ومعها الاستعلام الفرعي . 


: )٥( مثال‎ 

اعرض أسماء ووظائف الموظفين الذين يعملون على نفس وظيفة الموظف ذي الرقم (7369) 
ويآخذون مرتب آأكبر من مرتب الموظف ذو الرقم (787/6 ) . 
الإجابة : 

2 هذا المثال ثلاثة استعلامات اثنان منها استعلامات فرعية الأول يآتي بوظيفة الموظف ذي الرقم 
(7369) والثاني يأتي براتب الموظف ذي الرقم (7876) والاستعلام الثالث هو الرئيس . 


= 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


SQL> SELECT ename , job 
2 FROM emp )٥( إجابة المثال رقم‎ 


3 WHERE job = CLERK 
(select job * 
from emp 


where empno=7369 ) 


(select sal 
from emp 


where empno=7876) ; 


ملحوظة هامة : يجب آن تكون نتيجة الاستعلام الداخلي ( الفرعي ) عبارة عن صف واحد فقط حتى تتم 
المقارنة بشكل صحيح › وإلا فسوف تظهر رسالة خطاً كما ج المثال التالى : 


مثال (1) : 


SQL> SELECT ename , job 
2 FROM emp 
3 WHERE job = 
4 (select job رسالة خطاً‎ 
5 from emp ) ; 


ERROR : ORA-01427 : single -row subquery return more than one row . 


ظهرت رسالة خطاً 2 المثال السابق وذلك لأن الاستعلام الفرعى رجع بأكثر من وظيفة آي أكثر 
SQL> SELECT ename , job‏ 
FROM emp‏ 2 
WHERE job =‏ 3 
(select job‏ 4 
5 


from emp 
where ename='SMITH') ; 


سوف يرجع الاستعلام الداخلى (الفرعي) بوظيفة الموظف )8SM1118(‏ وهي )C1٤۸K(‏ أي إنه رجع 


E 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


الاستعلامات الفرعية المتعددة الصûفوdف‏ : Multiple-Row Subqueries‏ 
وهي استعلامات ترجع داقما بآڪثر من صف ولذلك يستخدم معها المعاملات المتعددة الصفوف 
(ALL, ANY , IN)‏ . 


والجدول التالي يبين معنى المعاملات المتعددة والتي تستحدم لمقارنة مجموعة من الصفوف : 


مثال (۷) : 
قم بعرض أسماء ورواتب وأرقام إدارات الموظفين الذين يأخذون رواتب مساوية لأقل راتب 4 كل 


إدارة 1 


SQL> SELECT ename , sal , deptno 
2 FROM emp 
3 WHERE sal IN ( select min(sal) 
from emp ( 800,950,130 ) دتيجة الاستعلام الفرعي هي‎ 
group by deptno ) ; 


JAMES 
MILLER 


ج المتال السابق لابد من إيجاد آقل راتب 4 كل إدارة وهذا بعمل استعلام فرعي يرجع بآقل 
الور ا ا ار رهی 007 1ر 050 600 ا هو ا ت رک ااا فر 
ا ق ق 


No 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


ملحوظات على المثال السابق: 

الاستعال القرفى ها هن محرد سن ايه 600950,100 نل مجمرعة هن 
الصفوف وهي آقل رواتب 4 كل إدارة . 

تم استخدام المعامل المتعدد )1N(‏ لأآننا هنا نقارن الراتب بمجموعة من الصفوف . 

فاا الرس ته عرض اتات الوطفن الدين با دون راتا هان اىن 
(800,950,1300( . 


مٹال (۸) : 
قم بعرض آرقام وأسماء ووظائف ورواتب الموظفين الذين رواتبهم آقل من راتب الموظفين أصحاب 
الوظيفة )C1٤۸)(‏ دون عرض موظفي الوظيفة ))٤R)(‏ . 


SQL> SELECT empno , ename , job , sal 
FROM emp 
WHERE sal <ANY aT 
( select SAL الفرعي هي‎ SSE 
from emp (800,950,1100,1300( 
where Job ='CLERK' ) 
AND job <>'CLERK' ; 


EMPNO | ENAME | JOB 


CIO TE E E E E 
كاك 3007 ,600,950,110 ف تدا هدد الم ك الإشقان انرس رض انات ارظن‎ 
الذين يآخذون رواتب آقل من آي من هذه القيم » كما تم استبعاد الموظفين المسجلين بالوظيفة‎ 
معناه بشرط أن يكون الراتب أقل من أكبر قيمة من‎ )54->A [N ۷( ونلاحظ أن المعامل‎ . ) CER ©( 

القيم (800,950,1100,1300) . 


TE 


تقنية الجاسب الآلي ۱ حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


مثال :)٩(‏ 
قم بعرض آرقام وآسماء ووظائف ورواتب الموظفين الذين رواتبهم أكبرمن كل المتوسطات 
الحسابية للمرتبات 2 كل إدارة 2 


SQL> SELECT empno , ename , job , sal 
2 FROM emp 


WHERE sal >ALL ۳‏ 3 
سيجه الاستعلام الفرعي ھی المتوسطات الحسابية \ select AVG(Sal)‏ ( 


5 from emp (2916.6667, 2175,1566.6667( 
6 group by deptno ) ; 


MANAGER 
ANALYST 
PRESIDENT 
ANALYST 


ك المثال السابق تم عمل استعلام فرعي لإيجاد المتوسطات الحسابية لرواتب الموظفين وكانت 
1566.6667 , 2175 , 2916.6667) ثم استخدام هذه القيم 2 الاستعلام الرئيس لعرض بيانات الموظفين 
ا ص O E EE a‏ ق و 
الراتب أكبر من أعلى قيمة من القيم (2175,1566.6667 ,2916.6667) . 


9 


تقنية الجاسب الآلي حاب الفصل السابع 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلامات الفرعية 


أسنلة الفصل السابع 
۱ - اكتب جملة استعلام أعرض آسماء وتواریخ تعيین الموظفىن الذين لهم نفس رقم إدارة الموظف 


: بحيث تظھر النتيجة کالتالی‎ 3 BLA K۳ 
HIREDATE 


20-FEB-81 


WARD 22-FEB-81 
MARTIN 28-SEP-81 
TURNER 08-SEP-80 
JAMES 03-DEC-S1 


و ر راد و اعا لون الان خرن راه كر الوط الال لحت ارو 
ورتب الناتج تتازليا حسب الراتب 9 بحيث تظهر النتيجة كالتالى : 


۷ اعرض ا وآرقام ادارات ووظائف الموظفىن المسجلىن _2 الادارة ٩ (DALLAS)‏ بحيیث تظهر 
النتيجة كالتالى : 
DEPTNO‏ 


MANAGER 


ANALYST 
CLERK 
ANALYST 
CLERK 


٤‏ - قم بعرض آرقام وأسماء ووظائف ورواتب الموظفين الذين يآخذون رواتب آقل من راتب 
الموظفين أصحاب الوظيفة (١M4؟8418)‏ دون عرض موظفى الوظيفة )8418SM4((‏ . ثم قم 
a‏ 


ا 


مقدمة قواعد بيانات أوراكل 


الاستعلام الفرعي المتعدد الأعمدة 


1 Len (rallsg) = 7 The Project ِ frmB mi [Code] 5 
Screen, HousePointer o 


Private aub cmALalc | 


frmMD1.stsStatusfar, P4 a 
Else | 


If tPausêflagf The 
End Sub 


Else 
CISL ATHTOTP 


E LTE J ELLE OT 1 
EHH 4S O3 + HEA o 


CRIPT language="JavaStE ipt"s 


iHSZLEion animateAnChor ll { 
WAE E]=eTERT,.SECE lermeEent ; 
if ("A"==e1].tagName} { #/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


ج و و و و و و و و و و و و و و و و و و و و و ص 


الاستعلام الفرعي المتعدد الأعمدة 
MULTIPLE-COLUMN SUBQUERIES‏ 


الجدارة : 
معرهة وفهم الاشتغلامات الفرعية أامتعددة الأعمدة وكيفية استخدامها . 


الأهداف : 

وا و ا 
E SA E e‏ 
NULL E O‏ 
ROM a 2 a E‏ . 


مستوى الأداء المطلوب : 
آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 


الوقت المتوقع للتدريب : أربع ساعات 
الوسائل المساعدة : 
© فلم . 


8 دفتر. 


متطلبات الجدارة : 


- ۹۸ - 


تقنية الحاسب الآلي ۱ حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


الفصل التامن : مقدمة 


2 الفصل السابق تم معرفة نوعين من الاستعلامات الفرعية النوع الأول كان الاستعلام الفرعي ذو 
الها ال ادرا ر و و ع الو اا خر الا اا دد اف الي ر 
بأكثر من صف » ويوجد نوع ثالث من الاستعلامات وهو الاستعلام متعدد الأعمدة والذي يرجع بآڪٽر 
من عمود وآأكثر من صف ولقارنة ناتج هذا النوع لابد من استخدام المعاملات متعددة الصفوف والتي تم 
E E‏ 


والشكل التالى يبين الصيغة العامة التي نستخدمها 4 كتابة هذا النوع من الاستعلامات . 


الصيغة العامة لجملة الاستعلامات الفرعية متعددة الأعمدة : 


) الاستعلام الخارجي ( الرئيس‎ 
SQL < SELECT ڌsيولطمنا مجموعة الأعمدة‎ 
FROM Jaدجll‎ 
WHERE ( |دڌوne‎ ,„ ,مودلا‎ ...) IN 
) se]‌ee) عمودا‎ , ٣دومع‎ , ... 
۲٥۳0 الجدول‎ 
Where hi ) ; 


الاستعلام الداخلي ( الفرعي ) 


نلاحظ ان الاستعلام الفرعي يرجع بآڪٽر من عمود والتي يىم مقارنتها بالآعمدة الموجودة_2 حملة 
WHERE‏ . 


۹ 


تقنية الحاسب الآلي ۱ حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


4 هذا الفصل سوف نتعرف على جدول جديد يتم من خلاله شرح الأمثلة التي توضح كيفية 
استخدام الاستعلامات متعددة الآأعمدة وهذا الجدول هو جدول يمثل الأصناف المسجلة داخل طلب معين 


ITEM Table فliصÎلا‎ Jلودج‎ 


الكمية السعر الحقيقي رقم المنتج رقم الصنف رقم الطلب 
7 32 100860 
100890 
100861 
100860 
100861 
100870 
100890 
101860 
101863 
10 
10 


س 


س رم ړن ن ډیا ین طب ی O‏ نم 


LEA DEMOS LETE amd a 
. DEMO 


مثال (۱) : 
2 هذا المثال نريد عرض رقم الطلب ورقم المنتج والكمية لجميع الأصناف التي لها نفس رقم المنتج 
أولاً : عمل استعلام فرعي متعدد الأ غهدة لإيجاد رفم المنتح والكمية للأصناف داخل الطلب رقم 605 . 
ڪالاتى : 


SQL> select product Id , quantity 
2 from Item 
3 where order id=605 ; 


E 


تقنية الحاسب الآلي ۱ حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


نتيجة الاستعلام الفرعى السابق هى : 


100861 
100870 


100890 
101860 
101863 
10 


ثانياً : عمل استعلام رئيس يتم فيه مقارنة رقم المنتج والكمية لجميع الأصناف برقم المنتج والكمية 
للآصناف داخل الطلب رقم 605 أي بالنتيجة السابقة . ڪالاتي : 


SQL> SELECT order Id, product id , quantity 
2 FROM item 
3 WHERE (product id , quantity) IN سه‎ 
4 (select product id , quantity 
5 from item 
6 where order id=605 ) 
7 order id <> 605 ; الاستعلام الداخلي (الفرعي)‎ 


در حع بالنتحة المذأكور ة أعلاه 


PRDER ID PRODUCT ID QUANTITY 


100861 
100870 
10 


2 المثال السابق تم عرض الأصناف التي لہا نفس رقم المنتج والكمية للآصناف المسجلة داخل 
E E E E PL E E NECE STEER‏ 
(605) من النتيجة النهائية . وذلك لعرض النتيجة للآصناف الآخرى فقط . 


- ۱۰١ - 


تقنية الحاسب الآلي ۱ حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


عندما تكون نتيجة الاستعلام الفرعي N01]‏ آي إنه لا توجد نتيجة للاستعلام الفرعي » 2 هذه 


(ectedاse r0ws‏ 10) وتعنى آنه لا توجد أآى صفوف مطابقة للشرط 2 جملة W6۲۴‏ الموجودة 


داخل الاستعلام الرئيس والمثال التالي يبن ذلك : 
مال (۲) : 


للأصناف المسجلة داخل الطلب رقم 700 » مع استبعاد الأصناف للطلب 700 من النتيجة . 


SQL> SELECT order Id, product id , quantity 
2 FROM item 
3 WHERE (product _id , quantity) IN سه‎ 
4 (select product Id , س‎ « 
5 from item 
6 
7 


where order id=700 ) 
order_id <> 700 ; الاستعلام الداخلي (الفرعي)‎ 


NULL ةجzيتiلlı یرجہ‎ 


no rows Selected 


. (no rows selected). laرlaتخl‎ 


EE 


تقنية الحاسب الآلي ۱ حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


استخدام الاستعلام الفرعي 2 جملة ۴۸0M‏ . 

يمكن استخدام الاستعلام الفرعي 2 الجزء ۴۸0١‏ من جملة الاستعلام S٤81٤8٣1‏ » وذلك لعمل 

فض اة خر غر اتا كا لرن وا م سه اول ت ا 4 0 

ng E N NEE 
. FROM «jجl‎ 


مثال (۳) : 


اعرضص أسماء ورواتب وآرقام ادارات والمتوسط الحسابي للرواتب للموظفىين الات ياخذون رواتب 
أعلى من المتوسط الحسابي لإداراتهم . 


SQL> SELECT e.ename,e.sal,e.deptno,esub.salavg 
FROM emp e, (select deptno,avg(sal) salavg 
from emp سه‎ 


E 
group by deptno) esub الاستعلام الداخلي (الفرعي)‎ 


WHERE e.deptno = esub.deptno يعامل معاملة الجدول‎ 
AND e.sal > esub.salavg ; 


SALAVG 


2916.66667 
2175 
275 
2175 
1566.66667 
1566.66667 


2 المثال السابق تم عمل استعلام فرعي 2 الجزء ۴۸0١‏ وذلك لإيجاد المتوسطات الحسابية 
للرواتب حسب الإدارات تم تم عمل استعلام رئيس لعرض البيانات المطلوية بشرط آن يكون مرتب 
الموظفين الذين سيتم عرضهم آأكبر من المتوسط الحسابي للرواتب داخل الإدارة التابح لها . 


VAT = 


تقنية الحاسب الآلي ۱ حاب الفص الثامن 
الاستعلام الفرعى المتعدد الأعمدة 


البرمجيات مقدمة قواعد بيانات أوراكل 


اتک ها آنا اس ها الاستعلام اأفركين وڪانه حدول موحجود باسم (esub)‏ ويتڪون هذا الجدول 
مں عمودیں الأول يمثل آرقام الإدارات والثانی يمثل المتوسطات الحسابية للرواتب 2 ڪل ادارة « وبياناته 
ڪالا تي : 


SQL> select deptno,avg(sal) salavg 
2 from emp 
3 group by deptno ; 


DEPTNO SALAVG 


10l 2916.66667L 
01د‎ 2175| 
30| 1566.666067 
ولآننا هنا نقوم بعرض بيانات من جدولين » فلابد من ربطهما ببعض آي إننا نقوم بربط جدول الموظفين‎ 
: مع الجدول (10ء) المكون بالاستعلام الفرعى بالجملة التالية‎ e۶ 


WHERE e.deptno = esub.deptno 


Of 


تقنية الحاسب الآلي حاب الفصل الثامن 
الرمجيات مقدمة قواعد بيانات أوراكل الاستعلام الفرعى المتعدد الأعمدة 


کے 


أسئلة الفصل الثامن 


1 — اڪتب حملة استعلام ألعرض آسماء وآرقام الاإدارة ورواتب الموظفىن الذدين لہم نفس رفم الادارة وراتب 


DEPTNO 


MARTIN 


WARD 
TURNER 
ALLEN 


۲ - اعرض آسماء وآأسماء الاإدارة ورواتب الموظفين الذين لهم نفس رواتب وعمولة الموظفىين المسجلىن _2 
الإدارة (04۸[[458) 5 بحيث تظهر النتيجة كالتالى : 


RESEARCH 
RESEARCH 
RESEARCH 
RESEARCH 
RESEARCH 


بحيث تظهر النتيجة كالتالى : 


- 1۰۵0 


مقدمة فواعد بيانات أوراكل 


التعامل مح البيانات 


frmBmıi [Code] 


1 Len (rallsg) = I) FA Project - {Code} 
Sereen, HousePointer +, | [emacne 


| | PEivwate Sub cmAlalc Z| 

trmMDI.stsdtatusPar, 1 2 ERE 
EL 

If tPausêflagf The 


End Sub 


Else 


AS UT OT 


z2 Fh E] ھک‎ @ ¢ 


CRIPT larguage="davaSeript"> 
nt iH animateAnChor ld { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل التاسع 


الرمجيات مقدمة قواعد بیانات أوراكل التعامل مع البيانات 
التعامل مع البيانات 
MANIPULATING DATA‏ 
الجدارة : 


معرفة وفهم لغة التعامل مع البيانات ([0۷) وكيفية إصدار الجمل الخاصة بهذه اللغة . 


الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على: 
|١‏ -معرفة ما هي لغة التعامل مع البيانات (DML) Data Manipulation Language‏ . 
۲ -معرفة كيفية إضافة سجل آو عدد من السجلات إلى جدول معين باستخدام الجملة 
(INSERT INTO)‏ . 
۳ -معرفة كيفية التعديل 2 بيانات جدول معين باستخدام الجملة )0۴0۸1٤(‏ . 
٤‏ -معرفة كيفية حذف صفوف من جدول معين باستخدام الجlaة (DELETE FROM)‏ . 


مستوى الأداء المطلوب : 
آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 


الوفت المتوقع للقدريب : آربع ساعات 
الوسائل المساعدة : 


فلم . 


8 دفتر. 


متطلبات الجدارة : 


0¥ 


تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل التاسع 


الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 
الفصل التاسع : مقدمة 


لقد قمنا 2 الفصول السابقة بشرح جملة الاستعلام 58٤] ٤٨1‏ والتي تمكننا من عرض آي بيانات 
من جدول أو عدة جداول بالشكل المطلوب » و2 هذا الفصل سوف نتعرف على قسم مهم جدا من أقسام 
لغة SQ]‏ وهو لغة التعامل مع البيانات ([0™1) وهذه اللغفة تمكننا من التعامل مع البيانات داخل 
الجدول » حيث يتم من خلالما إضافة سجل آو سجلات )۸0W۷8(‏ جديدة إلى الجدول آو التعدیل 4 سجل 
أو سجلات معينة أو حذف سجل أو سجلات معينة . 
وتتكون لغة التعامل مع البيانات ([0™1) من عدة جمل وهي كالتالي : 
" جملة إضافة بيانات إلى الجدوJ INSERT INTO‏ . 
" جملة التعديل 2 بيانات الجدول ٤U۲۴0۸1۴ا‏ . 
" جملة حذف بيانات من ائلجدJa DELETE FROM‏ . 
وسوف نقوم بشرح كل جملة من هذه الجمل بالتفقصيل 4 هذا الفصل . 
إضافة سجل أو عدد من السجلات إلى جدول معبjù .(INSERT IN T0)‏ 
إضافة سجل آو سجلات جديدة إلى جدول هي عملية إضافة بيانات جديدة إلى جدول معين عن 


طريق استخدام جملة الإضalة (NSET INTO)‏ . 


الصيغة العامة لإضافة سجلات جديدة إلى جدول . 


SQL > INSERT INTO Jıج‎ ( عمودل , مود‎ „٣ عمود‎ 
VALUES CR. 


0 


جدول : اسم الجدول المطلوب إضافة سجلات فيه . 
( عمود ا وعمود ٣‏ , عمود' Cn‏ اها الأعمدة المطلوب إدخال البيانات إليها ي 
" (قيمةا , قيمةا , قيمة ٣‏ .........) :القيم المطلوب إضافتها إلى الأعمدة . 


- 1۰۸ - 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


کے 
القواعد التي يجب التقيد بها عند الإضافة: 

ا ك ت ا ا ع ا 
INSERT‏ . 

)١ةميقلا( يجب أن تكون القيم مرتبة بنفس ترتيب الأعمدة المراد إدخال القيم إليها »> حيث إن‎ ١ 
و ك‎ E E 
. الأعمدة‎ 

عند إذخال قي التاريخ و التضوص لأب من وضها داخل غلامتى تيص فرديتين' 

Sle NNE ONE CET 
. ے2 جدول الموظفىن‎ )emP10( مثلا‎ (Primary key) 

۵ پجوز عدم ذكر أسماء الأعمدة 4 جملة [N5٤۴٣‏ و2 هذه الحالة لابد من إدخال جميع قيم 
الأعمدة الموجودة 2 الجدول حسب ترتيب الآأعمدة داخل الجدول مع مراعاة نوع البيانات لڪل 


عمود 


ملحوظة : يمڪن عرض آأسماء الأعمدة ونوع بياناتها داخل جدول معین باستخدام الآأمر 


مثال )١(‏ : إضافة سجل جديد إلى جدول الإدارات آي إضافة إدارة جديدة 


SQL> INSERT INTO dept (deptno , dname , loc ) 
2 VALUES ( 50, ' DEVELOPMENT" , 'DETROIT") ; 


جدول الإدارات )0٤۲1(‏ بعد الإضافة جدول الإدارات )0٤۲1(‏ قبل الإضافة 


السجل (الصف) الذي تم إضافته 


۔- 15۹ - 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


کے 

2 المثال السابق تم إضافة إدارة جديدة برقم (50) واسمھا )(٤۷E|L0°M8N1(‏ وموقعھا 

۴۴7 ) » ونلاحظ 2 هذا المثال اننا آخذنا 2 الاعتبار القيود التي يجب اتباعها عند الإضافة 

کا و م د كور اا أ ف اا مداخل الفرد. “فام6ل الذي وع انات 

() » وأضفنا أسم الإدارة وموقعها ووضعناهما داخل علامتي التتصيص الفردية (' ') وذلك لأن 
نوع بیاناتهما حروف (۷4۲°۸4۲2) . 


: إضافة قيمة فارغة (-لN) إلى عمود‎ 
E E E O ROLL 

ORTE SE NULL N a a ae J 

الثانية : أن نكتب الأعمدة ولكن نكتب قيمتها N01‏ داخل الجزء ۷۸10۴٤8‏ . 

بشرط أن تقبل الأعمدة هذه القيمة آي إنها ليست عليها قيود مثل (إء) ۹۲٣!٣م)‏ كما ك المثال 
اا 


هھ 


مثال (۲) : إضافة سجل جديد إلى جدول الإدارات يحتوي هذا السجل على رقم الإدارة واسمها فقط . 


SQL> INSERT INTO dept (deptno , dname ) 
2 VALUES (60, 'MIS') ; 


جدول الإدارات )0٤۴1(‏ بعد الإضافة 


E N TTS 


MIS 


NULL ةغرافa قيمة‎ 


ج المثال السابق تم إضافة إدارة جديدة برقم (60) واسمها )M15(‏ » ولكن لم يتم إضافة موفعها 


SQL> INSERT INTO dept (deptno , dname , loc ) 
2 VALUES ( 60 ,'MIS', NULL) ; 


YY 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


إضافة قيم خاصة داخل الأعمدة: 
إذا آردنا إضاهة تاريخ اليوم الحالي (5۲50۸1۳8) إلى العمود (۲11۸۴0(4۸1۳) الموجود داخل جدول 
الموظفين وذلك عند إضافة سجل جديد آي إضافة بيانات موظف جديد فيمكن عمل ذلك كما هو واضح 
من المثال التالي : 


مثال (۳) : إضافة بيانات موظف جديد إلى جدول الموظفين . 


SQL> INSERT INTO emp 
2 (empno , ename , Job, mgr „, hiredate „, sal , comm , deptno)LJ 
3 VALUES 
4 (7196 ,'AHMED' , 'SALESMAN', 7782, SYSDATE , 2000, NULL, 10); 


ج المثال السابق تم إضافة بيانات موظف جديد إلى جدول الموظفين وتم وضع تاريخ التعيين له بحيث 
ODT EE‏ 


المثال السابق دمڪن كڪتابته بحيیث لا ذنذڪر أسماء الأعمدة 2 الجزء INSERT‏ « وهنا لابد من 


كتابة ڪل القيم حسب ترتیب الآأعمدة داخل الحدول ڪالاتي 
SQL> INSERT INTO emp‏ 


VALUES 
(7196 ,'AHMED' , SALESMAN', 7782, SYSDATE , 2000, NULL, 10); 


إضافة سجلات عن طريق المتغيرات البديلة bleSۆVar1a Substıtut10¬‏ . 

تمكنا لغة 801 من عمل متغيرات تسمى المتغيرات البديلة » وهي عبارة عن مخزن مؤقت للبيانات 
ومن خلالہا يتم تخزين قيم معينة داخل هذه المتغيرات وأثاء تنفيذ جملة SQ‏ يتم استبدال هذه المتغيرات 
بقيمتها » ويتم تعريفها أقاء كتابة جملة 5Q1]‏ وذلك بوضع العامة (&) قبل آسم المتغير »> كما تظهر 
رسالة تسآل عن قيمة هذه المتغيرات آتاء التنفيذ . والمثال التالي يوضح كيفية إضافة سجل جديد 
باستخدام المتغيرات الئبديlة‏ lesۆVar1ab substitution‏ 


N 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


کے 


SQL> INSERT INTO dept ( deptno , dname , loc ) 
2 VALUES (&dept id , '&dept name', '&dept loc' ) ; 


Enter value for dept id : 80 
Enter value for dept name : EDUCATION المتغيرات البديلة‎ 
Enter value for dept loc : ATLANTA 


ج المثال السابق تم إضافة بيانات إدارة جديدة عن طريق استخدام المتغيرات البديلة التالية : 
(1d_اdep&)‏ متغير يمثل رقم الإدارة وعند التنفين تم تخزين رقم (80) داخله . 
(ameم_اdep&)‏ متغير يمتثل اسم الإدارة وعند التنفيذ تم تخزين (١0-4110(ع)‏ داخله . 
(10c_امde&)‏ متغير يمثل موقع الإدارة وعند التنفيذ تم تخزين )۸11-۸[N1۸4(‏ داخله . 

ويمكن تكرار هذا الآمر عدة مرات لإضافة أكثر من إدارة دون الحاجة إلى كتابة الآأمر مرة 

اکر 

وبهذا قد أضفنا إدارة جديدة إلى جدول الإدارات وكآننا كتبنا الأمر التالي : 


SQL> INSERT INTO dept ( deptno , dname , loc ) 
2 VALUES ( 80 ,'EDUCATION','ATLANTA'); 


يمڪن استخدام المتغبرات البديلة بدلا من أسماء الجداول والآأعمدة كما ج المثال التالي . 


مثال )٥(‏ : إضافة إدارة جديدة إلى جدول الإدارات باستخدام المتغيرات البديلة بدلا من سم جدول او 


سم عمود . 


SQL> INSERT INTO &dept table ( &dept_ id , dname , loc ) 
2 VALUES ( 80, 'EDUCATION','ATLANTA') ; 


Enter value for dept table : dept 
Enter value for dept id : deptno 


2 المثال السابق تم استخدام المتغير البديل (16ط_ام٥ل&)‏ بدلا من سم الجدول 4800) وأيضا 
لمتغير البديل (1_ d6‏ &) بدلا من أسم العمود (0١امءل)‏ . 


YT 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


إضافة سجلات جديدة عن طريق نسخها من جدول آخر : 

اقرض أن لدينا خد اسمه (0313801۲8) به بيانات المديرين » وجدول آاخر (0۳0۲) به بيانات 
الموظفين ونريد إضافة سجلات الموظفين الذين يعملون على وظيفة مدير(۲٥38١104)‏ إلى جدول المديرين › 
يتم عمل ذلك كما ج المثال التالي : 
مثال (1) : إضافة سجلات الموظفين الذين يعملون على وظيفة مدير من جدول الموظفين إلى جدول المدراء 


. (managers) 


SQL> INSERT INTO managers (id „, name , salary , hiredate) 
select empno , ename , sal, hiredate 


from emp 
where job="MANAGER' ; 


2 المثال السابق تم استخدام الاستعلام الجزئي التالي : 


2 select empno , ename , sal , hiredate 
3 from emp 
where job="MANAGER' ; 


IS 


وذلك لإيجاد الموظفين الذين يعملون بوظيفة مدير ومن ثم إضافتهم إلى جدول المديرين . لاحظ 
هنا عدم كتابة الجزء (ئعuأج۷)‏ . 


التعديل في بيانات سجل أو سجلات معينة داخل جدول (۷0۶(0۸1۴). 


التعديل 2 سجل آو سجلات معينة داخل جدول هي عملية تعديل بيانات عمود آو عدة أعمدة عن 
طريق استخدام جملة التعديل )0۴0۸1۴٤(‏ . 


الصيغة العامة لتعديل البيانات داخل الجدول . 


SQL > UPDATÊ Jaıج‎ 


قيمة۲ = عمود۲ , قيمة۱ = عمودا 9٤1‏ 
رط WHERE‏ 
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NYT = 


تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل التاسع 


الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


* جدول : اسم الجدول المطلوب تعديل سجلات فيه . 

" عمودا » عمود٣‏ : أسماء الأعمدة المطلوب التعديل فيها . 

E E EE EEE 

" شرط : شرط لاختيار سجلات (صفوف) معينة للتعديل فيها » وبدون هذا الشرط 
فسوف يتم التعديل 4 جميع السجلات . 


القواعد التي يجب التقيد بها عند التعديل : 
١‏ يجب آن يكون نوع البيانات الجديدة من نفس نوع بيانات الأعمدة المطلوب التعديل فيها. 
عند تعديل قيم التاريخ أو النصوص يجب وضع القيم الجديدة بين علامتي التنصيص الفردية 
(' '). 
يجب أخذ الحذر عند كتابة الجزء ۴ W1۴8‏ ب جملة التعديل لتحديد أي الصفوف التي 
سوف يتم التعديل فيها . 


مثال (۷) : تعديل أسم الإدارة رقم (30) ليصبح )£D€°۸110×(‏ بدلا مj )SALES)‏ 


SQL> UPDATE dept 
2 SET dname='EDUCATION' 4— (30) القيمة الجديدة لاسم الإدارة رقم‎ 


3 WHERE deptno=30 ; 


رسالة تدل على أن التعديل تم 2 الإدارة رقم )30( قط row updated q—‏ 1 


4 المتال السابق تم تعمديل أسم الإدارة رقم (30( (EDUCATION) yJjإ| (SALES) jn‏ 
باستخدام أمر التعديل (أمعل )0P241٤2 ٠‏ 2 جدول الإدارات » ولاحظ اختيار رقم الإدارة (30) 
باستخدام الجزء H۴ R۴‏ » ماذا يحدث لو لم نحدد الإدارة رقم (30) ؟ أي ماذا يحدث لو الغينا جملة 
الشرط WHER ۴٤‏ من المثال السابق ؟ 

عند عدم كتابة الشرط ب عملية التعديل أي لم يتم تحديد الصف المراد التعديل فيه فإنه يتم 
التعديل 2 جميع الصفوف كما 2 المثال التالي : 


NE 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


کے 


مثال (۸) : تعديل أسم الإدارة رقم (30) ليصبح )£D€°۸110×(‏ بدلا مj )SALES)‏ 


SQL> UPDATE dept 
2 SET dname='EDUCATION' ; 


أن التعدیل تم ے4 جمیع انلصفوف row updated q—‏ 4 


عند التعديل 2 صف معين فلابد من تحديد الصف المراد التعديل فيه باستخدام الجزء )WH۴R٤(‏ . 


اافول 2 کی د 

Se Rll DE NS EE BE ES 
ERN as BEARD ELE a a o 
: فماذا نقعل ؟ انظر المثال التالي‎ » )WAR( 


SQL> UPDATE emp 
2 SET (job , deptno) = (select Job , deptno from emp where ename='"'WARD') 
3 WHERE ename='BLAKE' ; 


نتيجة الاستعلام الفرعي )30 (MANAGER‏ 


1 row updated 


4ے المثال السابق نم عمل استعلام فرعي متعدد الأعمدة لايجاد وظيفة ورفقم الادارة للموظف 
Eas BEAR ELA SEL N ENS E SO VARD)‏ 
فقد تم التعديل 2 العمودين (10مpء‏ , ا٥ل)‏ للموظف )BL|LAK٤(‏ . 


حذف سجل أو سجلات معينة داخJ‏ ڄدJg .(DELETE FROM)‏ 


حذف سجل آو سجلات معينة داخل جدول هي عملية إلغاء بيانات عمود آو عدة أعمدة عن طريق 
استخدام جمlة‏ اlحذA“ (DELE1IE FROM)‏ . 


- ۱° 


تقنية الجحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


الصيغة العامة لحذف البيانات من الجدول . 


SQL > DELETE FROM Jyدج‎ 


WHERE ضرف‎ 


اکر اا 
يتم حذف جميع السجلات (الصفوف) . 
الا غو ال كت اح وا هه اا 
١‏ يجب الحذر عند كتابة الجزء WV] ٤۴R۴‏ 2 جملة الحذف لتحديد آي الصفوف التي سوف 
ا 


مثال )٠١(‏ : حذف الإدارة رقم (40) من جدول الإدارات . 


SQL> DELETE FROM dept 
2 WHERE deptno = 40 ; 


1 row deleted. 


ج المثال السابق تم حذف الإدارة رقم (40) من جدول الإدارات » أي إنه تم حذف صف ڪامل من 
الحدو : 
مثال )١١(‏ : حذف جميع الموظفين من جدول الموظفين . 


SQL> DELETE FROM emp ; 


14 row deleted. 


N 


تقنية الحاسب الآلي ۱ حاب الفصل التاسع 
الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 


کے 
ج المثال السابق تم حذف جميع الصفوف من جدول الموظفين وذلك لعدم تحديد الصف آو الصفوف 
المراد حذفها آي إننا لم نكتب جملة الشرط ۷1٤۸٤‏ ع المثال السابق . 
( تنبيه : الرجاء عدم تتفيذ الأمر السابق للمحافظة على بيانات الجدول » وإذا كنت قد فعلت 
فاكتب الأمر )۸0[1-84٣06(‏ لاسترجاع البيانات ) . 


مثال )١١(‏ : حذف جميع الموظفين المسجلين 2 الإدارة التي لہا اسم )584[1٤58(‏ . 


SQL> DELETE FROM emp 
2 WHERE deptno=( select deptno from dept where dname='SALES') ; 


ص ڪڪ 


نتيجة الاس“ لاہ التر هوا ن )30 row deleted.‏ 6 


4ے المخال السابق نم فمل استعلام فرعي لايجاد رفم الادارة التي ا آسم (SALES)‏ من جحدول 
الادارة رفم (30) › وبالتالي فقد تم حذف آڪثر من صف من جدول الموظفىن . 

ماذا يحدث لو آردت حذف الإدارة رقم (10) من جدول الإدارات 5 للاإجابة على هذا السؤال دعنا 
نرى هذا المثال . 


مٹال (۱۳) : 


SQL> DELETE FROM dept 
2 WHERE deptno= 10 ; 


ERROR at line 1 : 
ORA-02292 : integrity constraint ( USR.EMP DEPTNO_FK) 
Vaiolated —-child record found 


عند حذف الإدارة رقم (10) من جدول الإدارات ظهرت رسالة خطاً تبين آنه تم انتهاك قيد 
آو شرط ربط حدول اللادارات بجدول الموظفىن ( ومعلی ذلك آنه لا يمكن حذف الاإدارة رفم (10) وذلك 


يسيب أنه يوحد موظفون مسجلون 2 هده الادارة داخل الحدول (emp)‏ وذلك أوحود ريط 
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تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل التاسع 
البرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 
کے 
بين الجدولين عن طريق العمود (00مء) فهو بالنسبة لجدول الإدارات یعتبر مفتاح آساسي ( ۲۲1٣21۷‏ 
¥ع) وبالنسبة لجدول الموظفين فيعتبر مفتاح ربط (Foreign Key)‏ . 
عمليات فواعد البيانات (Database Tra41S4cti01S)‏ 
A AIRE CLES E a NENE SE a‏ 
ئl Database trans‏ وهي عملية انتقال البيانات من مرحلة إلى آخرى فمٹلا عندما نقوم بعمل 
إضافة سجل إلى جدول ما فإن هذه الإإضافة لا تتم بشكل نهائي إلا إذا قمنا بإصدار آمر من آوامر 
Database transactions‏ وهو الأمر ))0MM11(‏ وهذا الآمر يعني تثبيت آو حفظ البيانات بشكل 
اا ل وا اا و اال ا امر غ( 0 64:. 
وإليك بعض آوامر )۲4۸52٥)1018‏ eئaطهاة0‏ وهي كالتالي : 
C0MMI1‏ يموم هذا الآمر بحفظ البيانات التي تم إجراء عمليات الإإضافة آو التعديل أو 
ا 
۴0B ACK °‏ يقوم هذا الأمر بالتراجع عن عملية الإضافة أو التعديل أو الحذف . 
مر حفظ البيانات بشكل نهائي 00M M11‏ . 
E EAA‏ 
الأولى : ينفذ هذا الأمر بمجرد كتابته مباشرة بعد عمليات الإضافة والتعديل والحذف كالتالي : 


SQL> DELETE FROM emp 
2 WHERE deptno = 30 ; 


6 row deleted. 


SQL> COMMIT ; 


ج المثال السابق تم حذف الموظفين الذين يعملون بالادارة رقم (30) ولكن ليست بصورة نهائية 
وحتى يتم الحذف بشكل نهائي لابد لنا من إصدار آمر -C0MN×11‏ ڪما هو واضح آعلاه . 

E N E E E E E N 
ادها شو ادامر اهر عرف الا ات( 00ا0 و افر رام‎ 60 5 
: التحكم 2 البيانات (-0€©1) مث‎ 

(CREATE VIEW, CREATE TABLE , DROP TABLE , CONNCET ...... ) 


E A e 


- ۱۱1۸ - 


تقنية الحاسب الآلي ۱٦۱‏ حاب الفصل التاسع 


الرمجيات مقدمة قواعد بيانات أوراكل التعامل مع البيانات 
أسئلة الفصل التاسع 


5 آضف بيانات الموظفين التالية إلى جدول الموظفين 5 ومن ثم تحقق من إتمام عملية الإإضافة‎ - |١ 
: البيانات هى كما يلى‎ 


EMPNO_ | __ENAME HIREDATE COMM DEPTNO 


1111 AHMED ENGENEER 7839 01-01-2004 5000 
2222 SAUD SALES 7698 05-02-3 3000 


۲ - قم باصدار الآمر اللازم لحفظ هذه البيانات 2 الجدول ؟ ثم قم بالتعديل 2 راتب الموظف 
فم با ر الامراللازم : e a iT‏ جل ج ر 
)AHMED)‏ ليصبح (7/000) . 


۲ - قم بتعديل مرتبات الموظفين الذين تقل راوتبهم عن (900) لتصبح رواتبهم الجديدة (1000) . ثم قم 


. )2222( قم بحذف بيانات الموظف ذي الرقم‎ - ¿٤ 


۵ - فم بكتابة الآمر اللازم للإضافة بیانات موظفىن جدد بحيث إنك تكتب هذا الآأمرمرة وأاحدة فقط 
دون إعادة كتابته £ كل مرة تريد إضافة بيانات موظف جديد ؟ 


RS 


مقدمة فواعد بيانات أوراكل 


انشاء الجداول 


frmBmıi [Code] 


1î Lenlrslsg) = Û I) FA Project - [Code] _ 
Sereen, HousePointer +, | [emacne 


| | PEivwate Sub cmAlalc Z| 

trmMDI.stsdtatusPar, 1 2 REET = 
REL 

If tPausêflagf The 


End Sub 


Else 


AS UT OT 


z2 Fh E] ھک‎ @ ¢ 


CRIPT larguage="davaSeript"> 
nt iH animateAnChor ld { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 


الرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 
انشاءالجداول 


CREATING AND MANAGING TABLES 


الجدارة : 
معرفة وفهم كيفية إنشاء الجداول داخل قاعدة البيانات. 


الأهداف : 
E Nd NIB‏ 
| -معرفة آنوع الكائنات داخل قاعدة البيانات. 
۲ -معرفة آنواع البیانات 0۸1۸۲۷۶۴8 . 
۲ -معرفة كيفية إنشاء الجداول . 
O E E‏ 
۵ -معرفة كيفية التعديل 2 بناء الجداول ( إضافة وتعديل وحذف أعمدة ) 
٠‏ -معرفة كيفية إلغاء جدول من فاعدة البيانات . 
۷ -معرفة كيفية تغيير أسم جدول إلى أسم معين . 
۸ -آنواع الجداول 2 بيئة فواعد البيانات آوراكل . 


مستوى الأداء المطلوب : 

آن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 
الوفت المتوقع للقدريب : آربع ساعات 
الوسائل المساعدة : 


فلم . 


8 دفتر. 


متطلبات الجدارة : 


SYN 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


کے 


الف ت ف د هه ي دا ووا ر 
Data Definition Language )‏ ) والتي ا ما يرمز لہا ب (-[001) › وهذه اللغة هي التي تمكننا من 
إنشاء وتعديل وإلغاء آي كائن داخل قاعدة البيانات » وكما هو معروف آن قاعدة البيانات تتكون من 
كاتنات مختلفة وأهم هذه الكائنات هي الجداول )131٥5(‏ والتي سوف نركز ب هذا الفصل على 
كيفية إنشاتها والتعديل فيها وإلغائها . وإليك بعض الكائنات التي تتكون منها قاعدة البيانات : 


هو الوحدة الآساسية لمكونات قاعدة البيانات والتى نستخدمها 2 حفظ البيانات 
٠ Table‏ 


ويتكون من عدة صفوف وأعمدة . 


المناظير : عبارة عن جزء مؤقت من جدول معبن يتكون من عدة صفوف وآعمدة 
1€W‏ 
9د يستخدم لغرض معن بشڪل مؤفت . 


$ سلسلة : عبارة عن سلسلة تستخدم لتوليد آرقام متتالية بشكل معبن دون تكرار 
equence‏ ٍ 
SS Nea E E‏ 
فهرس : ويستخدم 4 عملية فهرست بعض الأعمدة لتسهيل عملية اليحث فيها 


SAE Ca E E a a E 
E aT 


Index 


وڪما سيق دڪره فاا سوف نرڪز 2 هنا الفصل على ڪائن واحد وهو الحداول (Tables)‏ . 


E 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


أنواع البيانات ؟PE¥† DATA‏ . 
ECE E E E N E EOE ESE CE EET‏ 
و عددية أو بيانات تاریخ آو بیانات آخری والجدول التالی يبن آنواع البيانات المختلفة : 


a ar 
تستخدم مع البيانات الحرفية الثابتة الطول لابد من تحديد‎ ٥12۲ (الحجہ)‎ 
طول البيانات الحرفية‎ 
تخد متم السانات الرفمة وشل الحرف رم )الا‎ 
الصحيح قبل العلامة العشرية › والحرف (58) يمثل الجزء‎ Number(p,s) 
. العشري بعد العامة العشرية‎ 


تستيخدم لتمثيل البيانات الكبيرة الحجم التي تصل إلى (2) 
تستخدم لتمثيل البيانات الكبيرة مثل الصور والرسومات 
والتي تصل حجمھا إلى آكثر من (4) جيجا بايت 

تستخدم لتخزين الملفات الكبيرة والخارجية والتي يصل 
حجمها إلى آڪٽر من (4) جيجا بايت . 


Long 


CLOB - BLOB 


ارو اا او رو ع ا ت ا ا ا ع 
# يجب آن يبدأ اسم الجدول أو آسم العمود بحرف . 
ق a‏ 
من الممكن آن يتكون من حروف كبيرة وصغيرة وآرقام ورموز خاصة مثل (# ,5$ ,_). 
١‏ يجب آن لا يتكرر آسم الجدول آأكثر من مرة داخل قاعدة البيانات الواحدة . 


YT = 


تقنية الحاسبا ۱٦۱‏ حاب الفصل لحاشر 


وراکل إنشاءالجداول 


3 


C+ 


الرمجيات مقدمة قواعد بيانا 


© يجب آن لا يتكرر آسم عمود آڪثر من مرة داخل الحدول الواحد. 
يجب أن لا يكون من الاسماء المحجوزة لأوراڪل مث )... (FROM , SELECT‏ . 


» » «e 


١‏ يفضل آن يكون آسم الجدول له معنى بحيث يعبر عن نوع بيانات الجدول. 


. CREATE TABLES JgIدڄل|‎ sll 


مثال )١(‏ : إنشاء جدول الإدارات (2٤صء4)‏ . 


SQL > CREATE TABLE dept2 ( 
2 deptno NUMBER{@) , 
3 


dname VARCHARZ2([4) ,‏ ا 
loc VARCHAR2(03) ) :;‏ 4 
Table created .‏ 


« 
۵ 


ك المثال السابق تم إنشاء جدول الإدارات )1P2(‏ والذي يتكون من ثلاثة أعمدة › العمود الأول 


نوعه رقمي وطوله (حرفان ) » والعمود الثاني نوعه حر وطوله ( ٠١‏ حرفا) » وكذلك العمود الثالث 
نوعه حرے وطوله (۱۳ خرف ٤)‏ وعندما درید عرض اليتاء الداخلى للجدول الذي تم إنشاوه تقوم بكتابة 


: الآمر التالى‎ 
SQL > DECRIBE dept2 ; 
Name Null? Type 
DEPTNO NUMBER{@) 
DNAME VARCHAR2([4) 
LOC VARCHAR2([3) 


TE 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


إنشاء الجداول باستخدام الاستعلامات الفرعية : 


يمكن إنشاء جدول باستخدام جدول آخر موجود مسبقا ب قاعدة البيانات » فمثلا لو أردنا إنشاء 
aE a El SCE LE‏ 
جديد أو تحديد نوع البيانات فيها » فمثلا إذا أردنا إنشاء جدول خاص يحتوي على بيانات الموظفين 
للاإدارة رقم (30) فقط عن طريق جدول الموظفين )5E۷۴(‏ » فإننا نقوم بكتابة الأمر كما ب المثال 
ااا 


e 


مثال (۲) : إنشاء جدول للادارة رقم ( 30 ) باستخدام بيانات جدول الموظفين ( N۴‏ ). 


SQL > CREATE TABLE dept30 
2 AS 
3 SELECT empno , ename , sal*12 annsal , hiredate 


4 FROM emp الاستعلاہ اأ‎ 
5 WHERE deptno = 30 ; ا‎ 


Table created . 


EEE 


2 المتال السابق نم انشاء حدول خاص بالادارة رقم (30) یبسمیىی (dept30)‏ باستخدام 
جملة أ٥ع1عء‏ 2 الاستعلام الفرعي المبين 2 المثال » ونلاحظ أننا استخدمنا الجزء )۸A8(‏ 4 جملة إنشاء 


۶ 


الحدول والحدول المسمى ا (dept30)‏ ڪون فين أريهة عم ده هي 

»)empno,ename,annsal,hıredate)‏ والجدول الجديد (30مء) يحتوي على بيانات الموظفين ج2 الإدارة 

(30) آئ إننا عندما نتش جدولا باستخدام الاستعلام القرعي يتم نفل البيانات من الجدول المستخدء د 
SQL > DECRIBE dept30 ;‏ 


Name Null? Type 

EMPNO NOT NULL NUMBER(@G) 
ENAME VARCHAR2([0) 
ANNSAL NUMBER 
HIREDATE DATE 


- 1° 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


وعندما نقوم باستعراض البيانات من الجدول (30مء0) تكون النتيجة كالتالي : 


SQL> SELECT * FROM DEPT30 ; 


HIREDATE 


20-FEB-81 
22-FEB-81 


MARTIN 28-SEP-81 
BLAKE 01-MAY-81 
TURNER 08-SEP-81 
JAMES 03-DEC-S1 


أا ا و ياء ا عة هي ي اا اة ا ر 2 ا 
الاستعلام ( وعندما ريد انشاء تفس الحدول أو آي جدول آخر باسماء محددهہ غير الاسماء الموجودة_2 
جملة الاستعلام فإننا نكتب الأمر كما ج المثال التالى : 


مثال (۳) : إنشاء جدول للادارة رقم )20) باستخدام جدول الموظفين (EMP)‏ يحتوي غلی آسماء 
أعمدة مختلفة عن الأعمدة 2 جدول الموظفين (N۶٧١ع)‏ . 


SQL > CREATE TABLE dept20 
6 (emp_id,emp_name , salary , start _ date ) 
7 AS 
8 SELECT empno , ename , sal , hiredate 


9 FROM emp الاستعلام الفرعي‎ 
10 WHERE deptno = 20 ; 
Table created . 


pe ERNEST 
o O O O O O gS 


5 


E TE E E E E E E E e E E E E E e E A E E A E e E E a E E E a E E E E E E E E E E E E E E E E E e E A E E E E E E E E E E E E E a e E E E E E E 


E E O A EE E E 
: الموظفىن للادارة رفم (20) › ويتڪون من الأعمدة التالية‎ 


(emp_ 1d, emp name , salary , start date) 


VT 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


کک کے 


.ALTER TABLE مIدختسlڊ‎ Jوادجلا التعديل في‎ 


ER NE E E COE OS 
2 Nag ATER TAET ge a E E E ED 
الجداول تشتمل على ثلاث إمكانيات وهى إما إضافة أعمدة جديدة على الجدول آو التعديل ے2 نوع بيانات‎ 


عمود معين آو إلغاء عمود معين . كما هو موضح بالجدول التالي : 


ALTER [A SLE I I أ الفدل 2 ا‎ 


تسخدم لإضافة أعمدة جديدة إلى الجدول 
 ] ۴¥‏ تستخدم للتعديل 4 نوع البيانات للجدول 


DROP‏ تستخدم لإلغاء عمود معين من الجدول 


مثال )٤(‏ : إضافة عمود جدید یسمی (8۴610۸) إلى جدول الإدارات 0٤۴12‏ . 


SQL> ALTER TABLE dept2 
2 ADD ( region VARCHAR2(20) ); 


Table altered . 


E‏ س اد ی 0 وا ا ا 
يحتوي قل انه بیانات ويمڪن حفظ بيانات المناطق لكل إدارة « ويظهر هذا العمود ڪآخر عمود عد 


SQL > DECRIBE dept2 ; 


Name Null? Type 

DEPTNO NUMBER{/2) 
DNAME VARCHAR2([4) 
LOC V ARCHAR2([3) 
REGION VARCHAR2(20) 


YN 


تقنية الجاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
الرمجيات مقدمة قواعد بيانات أوراكل إانشاء الجدا 
رمج ب ! جداو 


مثال (۵) : التعدیل 2£ طول بیانات العمود )05×N۸M٤(‏ ل ل 20 بدلا من 14 . 
لعمو أليصبح د من 


SQL> ALTER TABLE dept2 
2 MODIFY ( dname VARCHAR2(220) ); 


Table altered . 


2 المثال السابق تم التعديل 2 نوع بيانات العمود ۵1410۴ ليصبح طوله (2)20 ۷۸۸٣11۸۴‏ بدلا من 
VARCHAR 214)‏ » ويجب أخذ الملحوظات التالية £ الاعتبار عند التعديل 2 أعمدة الجداول : 
" يمكن زيادة حجم (طول) البيانات للأعمدة . 
" يمكن تغيير نوع البيانات من نوع إلى آخر بحيث لا يؤثر ذلك 2 بيانات الأعمدة إذا كانت 
موجودة . 
" لا يمكن تقليل حجم (طول) الأعمدة إذا كانت تحتوي على بيانات . 


مثال (1) : إلغاء العمود المىىمى ×10 R٤6‏ من جدول الإدارات 9٥5٤۴1‏ . 


SQL> ALTER TABLE dept2 
2 DROP COLUMN REGION ; 


Table altered . 


2 المثال السابق تم إلغاء العمود ((۸۴610) من جدول الإدارات (08۴12) » ويجب أن نأخذ ك 
Sa Ge Na E EOE‏ 


ا كن او ا ا وا م ات 

و کو ا و الاک 

" يجب أن يتبقى عمود واحد على الأقل بعد عملية الإلغاء داخل الجدول 
ا و ن 


ITA = 


تقنية الحاسبا ۱٦۱‏ حاب الفصل لحاشر 


البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


3 


C+ 


الغاء جدول باستخدام الأمر 5۸0۴ . 


E O EE EA CC DEG Sas 
. القيود المتعلقة به » وبالتأكيد لا يبمكن استعادته مرة آخرى‎ 


مثال (۷) : إلغاء الجدول المسمی ب )0٤۲۶۲30(‏ . 


SQL> DROP TABLE dept 30 ; 
Table dropped . 


4ے المثال السابق نم إلغاء جدول موظفي الادارة رقم (30) والذي فد نم انشاژه و ویسمی 
ڍ)30 (DEPT‏ . 


تغيارأسم جدول معبن إلى اسم آخر ڊlستخدIم‏ |!ٺمر RENAME‏ . 


لر اسه الجدول 5215(7 ل اة ا EPA 1E N7‏ 0 قوم كتا الأ عر كا 
هو مبين بل المثال التالي : 


مثال (۸) : تغيير اسم جدول الإدارات (12 £۴( ليصبz (DEPARTMENT) ıl‏ . 


SQL> RENAME dept2 TO deptartment 
Table renamed. 


کان هو الك ها الو 


AEE 


تقنية الجاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
الارمجيات مقدمة قواعد يانات أوراكل إنشاءالجدا 
Ê‏ 2 9 1 جد و 


سک کے 


أنواع الجداول في بيئة قواعد البيانات أوراكل . 


AEN EN Oa 

* جداول تنشاً عن طريق المستخدمين 9٤۸ 148]٤5S‏ » وهي مجموعة من الجداول ينشتها 
المستخدم ويتم التعامل معها من خلاله . 

* جداول یتم إنشاڙها عن طریق خادم آوراکل ٤ 5٤۸۷ ٤۸(‏ ]ل٣۸‏ 0۸) » وهي مجموعة من 
الجداول تسمى 01٣-110١.N۸R۷(‏ 0۸14) »> يتم إنشاؤها بواسطة آوراكل وهي تحتوي 
على معلومات عن فاعدة البيانات . 

وتنقسم إلى عدة فثات هي : 

" الفئة )119٤۸_(‏ : وتحتوي على معلومات حول الكائنات الخاصة بالمستخدمين مثل الجداول . 

" الفئة (_۸11) : وتحتوي على معلومات عن كل الجداول والعلاقات التي يمكن للمستخدمين 


E 
)0(8۸( الفكة (_0(84) : وتحتوي على معلومات خاصة بمدير قواعد البيانات‎ " 


. (DATA DICTIONARY) 


SQL> SELECT * 


2 FROM user tables ; 


مثال )٠١(‏ : عرض أسم ونوع الكائنات التي يمتلكها المستخدمون . 


SQL> SELECT object name , object type 
2 FROM user _ objects ; 


SQL> SELECT * 
2 FROM user catalog ; 


YT 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 
البرمجيات مقدمة قواعد بيانات أوراكل إنشاء الجداول 


أسنلة الفصل العحاشر 
البناء الداخلي لهذا الجدول 5 


Column Name Jd 
Key Type ا‎ | 
Nulls/Unigue اى 000000000 .ا‎ 


Name 


FK Table aS 
FK Column ا‎ 


Datatype 
Length 


۲ - قم بإنشاء جدول للموظفین یسمی E۷۶10 ۷٤٤‏ حسب الوصف التالي » ثم قم باستعراض البناء 
الداخلي لهذا الجدول ؟ 


| Column Name (ID 
Key Type 0 0 ا ا‎ 
Nulls/Unigue | | 


LAST NAME ` FIRST NAME DEPT ID 


FK Table 
FK Column 


Datatype 
Length 


٣‏ - قم بتعدیل جدول للموظفین EM1 ۲10۷۴٤‏ لیصبع طول العمود LAS1_ NAV٤‏ (50) بدلا من 
(25) . لیصبح البناء الذاخلی کالتالی ؛ 


Name Null? Type 

ID NUMBER(7) 
LAST NAME VARCHAR2(60) 
FIRST NAME VARCHAR2(025) 
DEPT ID NUMBER(7) 


hS 


تقنية الجاسب الآلي ۱٦۱‏ حاب الفصل لحاشر 


إنشاء الجداول 
ee EB SOTERA ga EMPLOYED aan JE‏ 
ورقم الإدارة ) معتمدا على جدول الموظفين E۴‏ بحيث يحتوي الجدول الجديد على الأعمدة التالية : 
(ID, LAST NAME , DEPT ID)‏ 5 


الارمجيات مقدمة قواعد بيانات أوراكل 


۵ - قم بإضافة عمود جدید اسمه RST NA۸M٤‏ إلى الجدول المسمی ب ۴۴2 EMP1L0¥‏ حدد نوع 
الات اا ا اله 


5 EMPLOYEE Jal Jلودجلا قم بإلغاء‎ - ٦ 
3 EMPLOYEE 4aٺ|‎ zبصيl‎ EMPLOYEE2 Jلودجلا قم بإعادة تسمية‎ - ۷ 


۸ - قم بإلغاء العمود LA81_N۸M٤‏ من الجدول ګEMP|LOYE‏ » واستعرض البناء الداخلي 


ST 


مقدمة فواعد بيانات أوراكل 


القيود على الجداول 


frmBmıi [Code] 


1 Len (rallsg) = I) FA Project - {Code} 
Sereen, HousePointer +, | [emacne 


| | PEivwate Sub cmAlalc Z| 

trmMDI.stsdtatusPar, 1 2 ERE 
EL 

If tPausêflagf The 


End Sub 


Else 


AS UT OT 


z2 Fh E] ھک‎ @ ¢ 


CRIPT larguage="davaSeript"> 
nt iH animateAnChor ld { 
WAE E]=pEFEnRT.SECE leEmeEnt ; 
if [("A"==e1].tagName] { #y/ Initialize effect 
iF Inull==el]l.EeffECTE] FEl.EffECtE = "hi qhl ] 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 


الرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 
الفيود على الجداول 
CONSTRAINTS‏ 
الجدارة : 


معرفة وفهم كيفية تطبيق القيود على الجداول . 
الأهداف : 
عندما يكتمل هذا الفصل يكون لديك القدرة على : 
| -فهم معنى القيود )٥١5۲۵1١٤١(‏ التي تطبق على الجداول . 
۲ -معرهة آنواع القيود كأ١K0151۲۹1‏ التي يمكن تطبيقها على الجداول. 
٣‏ -معرفة كيفية تطبيق القيود على مستوى العمود . 
؛ -معرفة كيفية تطبيق القيود على مستوى الجداول . 
ه -معرفة كيفية إضافة القيود على جداول تم إنشاؤها . 
٠‏ -معرفة كيفية إلغاء القيود من الجداول . 
- عرض القيود المطبقة على الجداول والآعمدة . 


کو 


مستوى الأداء المطلوب : 
أن يصل المتدرب إلى إتقان هذه الجدارة /٠٠١‏ . 


الوفت المتوقع للقدريب : آربع ساعات 
الوسائل المساعدة : 


فلم . 


8 دفتر. 


متطلبات الجدارة : 


a 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


الفصل الحادي عشر : مقدمة 


القيود هي عبارة عن شروط معينة توضع على الجداول لتنظيم العمليات المختلفة التي تتم على 
AEE sS a E E a‏ 
الجدول عمودا لتخزين رقم الموظف » وعندما نريد إضافة موظف إلى هذا الجدول ريما نضيف بيانات 
موظف جديد ويكون رقمه مثلاً (100) ويكون هناك موظف مسجل بنفس الرقم داخل الجدول › ك 
هذه الحالة يتم تخزين الرقم (100) 2 عمود (رقم الموظف) مرتين » آي إننا قمنا بتسجيل موظفين برقم 
واحد » وهذا غير منطقي أن يتم تسجيل موظفين أو آكثر برقم واحد » ولمذا فإننا نقوم بعمل قيد 
0 )ل ) على العمود (رقم الموظف) حتى لا يقبل رقم مكرر . 

NEEL a N ns 


- 1۳° 


ثقنية الحاسب الآلي ۱ حاب الفصل الجادي عشر 
ك معد هه فواعك ت اورا د و 
البرمجيات قدمة قواعد بيانات أوراكل القيود على الجداول 


أذواغ اليد Constraints‏ . 


)D‌esc-۲1p)101۸( معنى القید‎ (constra10t) ديقaلا‎ 


NOT NULL 
يطبق على مستوی العمود فقط‎ 
E N EN aa 
©“ UNIQUE 
O 


: تڪرار القيم « وعدم ترك القيم فارغة آي انه عيارة عن القيدين السابقىن‎ PRIMARY KEY 
. يطبق على مستوى العمود آو الجدول‎ 
. یستخدم لعمل مفتاح ربط بین جدولین‎ 
FOREIGN KEY 
. يطبق على مستوى العمود أو الجدول‎ 
1 CHECK 
. يطبق على مستوى العمود أو الجدول‎ 


. Create a Constrait إانشاء القيود‎ 


: القيود بطر يقتبن هما‎ O 
: عمل القيود اء انشاء الجدول‎ 
فل اة اء ادون‎ 


وتطبق القيود على مستوی الأعفدة أو على مسلوی الحدول . ڪما سنوضح ذلك من خلال 
ا 


TUS 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


کے 

. PRIMARY KEY ıd 

هذا القيد يتم إنشازه على مستوى العمود آو على مستوى الجدول » ومعنى هذا القيد هو إنشاء 
مفتاح آساسي (۴۷عK‏ ۲1۳0۵۲۷) داخل الجدول وذلك لتمييز عمود معين بحيث إن هذا العمود يكون له 
خاصیتان هما : 

. عدم قبول تكرار القيم داخله‎ - ١ 

ف السماح بترك فقيمته فارغة )NN€1(‏ . 

فمثلا إذا آردنا تمييز المتدريين فإاننا ا 8 الأكاديمي فهذا الرقم يجب آن 
ڪون و e‏ لا يتڪرر ا | ا ا و يجب آن يڪون 
لكل متدرب رقم آأكاديمي فليس من المعقول أن نسجل بيانات متدرب دون تسجيل رقمه › ولتحقيق ذلك 
نقوم بعمل عمود داخل جدول المتدربين ونطبق عليه القيد (ع) )P٣1۳۵۲y‏ . 


مثال )١(‏ : إنشاء القيود أثاء إنشاء جدول الإدارات وتطبيقها على مستوى | الأعمد 


SQL > CREATE TABLE dept ( 
deptno NUMBER{2) PRIMARY KEY,— 
ا‎ 


dname VARCHAR2(14) NOT NULL 3 
loc VARCHAR2([13) 
J 
القيود لین مستوی إل‎ 


E E E E E E 
القيد الأول هو (إء) ل3۲1۷١11١م) على العمود ٥0١امءل لجعل هذا العمود (مفتاح‎ » )deptn0,dnam( 
أساسي) داخل الجدول »> حيث إن رقم الإدارة يجب أن لا يتكرر داخل العمود وآيضا عدم ترك قيمته‎ 
6 

أما القيد الثاني (11" 10) على العمود ۸4۳8ل يمنع ترك قيمة هذا العمود فارغة بدون بيانات 
E E E I EE‏ 
)N01 '[[(‏ يطبق فقط على مستوى العمود آي إننا لا نستطيع تطبيقه على مستوى الجدول . 


3T N 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


مثال (۲) : إنشاء القيود أثناء إنشاء جدول الإدارات وتطبيقها على مستوى الجدول . 


SQL > CREATE TABLE dept ( 
2 deptno NUMBER{) , 
3 dname VARCHAR2([14) NOT NULL, 
4 loc VARCHAR2(03) , 
5 


CONSTRAINT dept deptno_pk PRIMARY KEY(deptno) ) ; 


القيد على مستوى الجدول . Table created‏ 


ے المثال السابق تم إنشاء جدول الإدارات (أ6٤4)‏ کما تم إنشاء فيد (إء) ۳۹۲۶٣1٣م)‏ على مستوى 
الوا واه د ا 0 واو و 
هوا ا ف ااا كان فلى ن الول ٠‏ و تحط د ها الان آنا مما القت د 
)dept_deptn0_pk&(‏ وبهذا يمڪن حذفه بسهولة كما ستنری لأسا 


نۉك UNIQUE KEY‏ . 
هذا القيد يتم إنشازه على مستوى العمود أو على مستوى الجدول › ومعنى هذا القيد هو عدم 
السماح بتكرار القيم داخل العمود . 


SQL > CREATE TABLE dept ( 
2 deptno NUMBERO@O) , 
3 dname VARCHAR2([4) , 
4 loc VARCHAR2(03) , 
5 


CONSTRAINT dept deptno uk UNIQUE(dname) ) ; 


القيد على مستوى الجدول . Table created‏ 


اال الان ت ناء جر ارات 0655 کم ف توعان 
lê SAEED E EES SN EE a E a Og‏ 
مستوى الجدول ويمكن تطبيقه على مستوى العمود . 


- 1۳۸ - 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


تيد FOREIGN KEY‏ . 
هذا القيد يتم إنشاؤه على مستوى العمود أو على مستوى الجدول » ويستخدم هذا القيد عندما 
نرید ربط جدولین ببعض » فمثلا لربط جدول الموظفين بجدول الإدارات بغرض معرفة موظفي إدارة 
معينة » فإنه لابد من وجود عمود K٥۷(‏ 11۳03۲۷) داخل جدول الإدارات ونفس هذا العمود يوجد 4 جدول 

الموظفين ويسمى (۷ءK )]٥١١18۸‏ » كما بے الشكل التالي : 


EMP table DEPT table 


7566 | JONES | MANAGER OPRATIONS BOSTON 


1 1 


Foreign Key Primary Key 


ولتتفيذ هذا الربط لابد من تطبیق القید )٥۲١181۸ )K٤۷(‏ على العمود (٥١م٥)‏ داخل جدول الموظفين 


مال )٤(‏ : إنشاء القيد K٤y۷(‏ ٣عآء۲ه)‏ على العمود 4٥۲٤١0٥0‏ 2 جدول الموظفين وتطبيقه على 


مستوی العمود 


SQL > CREATE TABLE emp ( 
2 empno NUMBER(A) , 

ename VARCHAR2(10) NOT NULL, 
job VARCHAR2() , 
mgr NUMBER(A) ۽‎ 
hiredate DATE, 
sal NUMBER(.2) , 
comm NUMBER(/,2) , 
deptno NUMBER{@) REFERENCES dept(deptno) ) ; 


القيد على مستوى العمود . Table created‏ 


YT 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


ج المثال السابق تم إنشاء جدول الإدارات (۳(Pع)‏ كما تم إنشاء قيد (إء) )]0٥۲۶18۸‏ على العمود 
(n0امepعd)‏ » لعلك تتساءل ین أفظ (yع) )٥۲۴181۸‏ هنا 5 نقول لك أن كلمة )AE٤۴٤R۸E٤N٣٤5(‏ تشیر 
إلى آنه تم تطبیق القید (إءK) )]٥۲۴18۸‏ على العمود (0١مءل)‏ الذي يشير إلى العمود (٥١مءd)‏ داخل 
الجدول ٤۴1‏ . وبهذه الطريقة تم تطبيق القيد على مستوى العمود . 

أما تطبيق القيد على مستوى الجدول فسوف يبين 2 المثال التالي : 


مثال )٥(‏ : إنشاء القيد (ر٤K‏ ”عآءاها) على العمود 0٥0١٤مءd‏ 2 جدول الموظفين وتطبيقه على مستوى 
الجدول . 


SQL > CREATE TABLE emp ( 
2 empno NUMBER(A) , 
ename VARCHAR2([10) NOT NULL, 
Job VARCHAR2() , 
mgr NUMBER(A) ۽‎ 
hiredate DATE, 
sal NUMBER(.2) , 
comm NUMBER(/,2) , 
deptno NUMBER{O) , 
0 CONSTRAINT emp deptno fk FOREIGN KEY (deptno) 
1 REFERENCES dept(deptno) ) ; 


دیا طب O‏ کے ûf‏ 0 )ا سس س 


القيد على مستوى الجدول . Table created‏ 


تيد CHECK‏ . 
هذا القيد يتم إنشاؤه على مستوى العمود آو على مستوى الجدول » ويستخدم هذا القيد عندما نريد 
ETE EE E E‏ 
aA oN E EO gO NS gE E Oa‏ 

واضح من المثال التالي : 


ET 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 


البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


مثال (1) : إنشاء القید ))۳1٤٤٤(‏ على العمود ٤۲۲۸0‏ 2 جدول الإدارات وتطبيقه على 


مستوى الجدول . 


SQL > CREATE TABLE dept ( 
2 deptno NUMBER{) , 
3 dname VARCHAR2(14) , 
4 loc VARCHAR2(03) , 
5 


CONSTRAINT dept _ deptno_ ck CHECK(deptno BETWEEN 10 AND 99) ) ; 


القيد على مستوى الجدول . Table created‏ 


ج المثال السابق تم إنشاء جدول الإدارات (أ6ءل) كما تم إنشاء قيد ()ءعطء) على العمود 0دامpعd‏ 
بشرط أن کون القيم المد خلة لہذا العمود محصورة ين (99, 10) . 


إضافة فبود على انجدlاJg‏ أConst(rai „Adding‏ 


SQL > ALTER TABLË Jgدجlا‎ مıÎ‎ 
ADD CONSTRAINT دıتلا‎ pu و نوع القيد‎ 


E E O E EE NI 


مثال (۷) : إضافة القيد )۴ORE16GN )۴٤¥(‏ على العمود MGR‏ 2 جدول الموظفين . 


SQL > ALTER TABLE emp 
2 ADD CONSTRAINT emp _ mgr fk 
3 FOREIGN KEY(mgr) REFERENCES emp(empno) ; 


Table altered . 


SYNE = 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 


البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


ج المثال السابق تم إضافة القید (yإعK) )٥۲۴٤۴12۸‏ إلى العمود (81۳) وذلك لريط رقم المدير لكل 
موظف برقم الموظف نفسه ونوع الربط هنا (1[010عء) » راجع الفصل السادس . 


مثال (۸) : إضافة القید (¥ )۶P ۸11۸ R۷ ۸٤‏ على العمود ٤۲1۸0‏ 2 جدول الإدارات . 


SQL > ALTER TABLE DEPT 
2 ADD CONSTRAINT dept deptno_ pk PRIMARY KEY(deptno) ; 


Table altered . 


ج المثال السابق تم إضافة القید (إء) )p۲1۳3۲۷‏ إلى العمود (٥١امءd)‏ ے جدول الإدارات وذلك 
4 حالة عدم إنشائه أثناء إنشاء الجدول . 


إزالة القيود من الجداول 0۸0۶. 


مثال (۹) : إزالة القيد المسمى د ()؟_g۲_م‏ ”۴ ) من جدول الموظفين . 


SQL > ALTER TABLE emp 
2 DROP CONSTRAINT emp_mgr fk ; 


Table altered . 


كما هو واضح من المثال السابق فقد تم إزالة |نقيد aul (Fore1gn key)‏ ڊ (emp_ mgr fk)‏ 
من الجدول (10۲ع€) . 


E 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


وكما نعرف آن جدول الموظفين له علاقة بجدول الإدارات وذلك عن طريق وجود مفتاح آساسي 
key(‏ Yص1ام)‏ علی العمود ٥٣مءل‏ داخل جدول الإدارات ووجود مفتاح (yء) )٤۲٥۴18۸‏ على نفس 
العمود 0١ء‏ داخل جدول الموظفين › فماذا نفعل عندما نريد إلغاء أو إزالة قيد المفتاح الأساسي من 
جدول الإدارات و2 نفس الوقت إزالة العلاقة بينه وبين جدول الموظفين آي نزيل المفتاح (yإء) )]٥۲٤18۸‏ من 
جدول الإدارات » ب2 هذه الحالة نقوم بإصدار الأمر كما ب2 المثال التالي : 


مثال )٠١(‏ : إزالة العلاقة بين جدولي الموظفين والإدارات عن طريق إزالة المفتاح الأساسي من جدول 


SQL > ALTER TABLE dept 
2 DROP primary key CASCADE ; 


ESEREN 


Table altered . 


2 
e 
٤ 
٤ 
ب‎ 4 


SE N O OS 
NEN aE ENE. OA ADD EE SEE 
. من جدول الموظفين‎ )۴ ٥۲٤١12٣ الأساسي آي يقوم بإزالة («ره)‎ 


استعراض القيود المطبقة على جدول معين : 


SNE SG OE E E E a 
ه04 . ومن خلالہا يمكن عرض القيود المطبقة على جدول معين‎ 01c)10١3۲۷ وهذه الجداول تسمى‎ 


YET = 


ثقنية الحاسب الآلي ۱ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 
SQL > SELECT constraint name , constraint type‏ 


2 FROM user constraints 
3 WHERE (table name ='EMP' ; 


CONSTRAINT _ NAME 


SYS_C00674 
SYS_C00655 
EMP EMPNO PK 
FK DEPTNO 


الال اسايق عرش أسماء القيود واتراعها العف على جنول الزطفين ٠‏ وكا تلاحظ آن تا 
عمود آنواع القيود )٤0158۲31١_P٥(‏ عبارة عن حرف واحد يدل على نوع القيد ومعنى هذه الحروف هي 
کا بلی.: 
" الحرف CU‏ يعني آن نوع القيد هو CH]٤CK&‏ . 
* الحرف ۴ يعني أن نوع القید ھو Primary Key‏ . 
* الحرف ۸ يعني آن نوع القید ھو k٤‏ e18۸إ۴‏ . 
" الحرف لا يعني آن نوع القيد هو N1۷0٤‏ . 
آما نوع القید N01 NU[[‏ فيظھر مثل الئقيد CHECK‏ . 


والمثال التالي يوضح ڪيفية عرض القيود المطبقة على الأعمدة 
مثال )١١(‏ : عرض أسماء الآأعمدة وأسماء القيوم المطبقة عليها . 


SQL > SELECT constraint name , column name 
2 FROM user cons column 


3 WHERE table name ='EMP ' ; 


YEE 


ثقنية الحاسب الآلي ۱٦۱‏ حاب الفصل الجادي عشر 
البرمجيات مقدمة قواعد بيانات أوراكل القيود على الجداول 


أسنلة الفصل الحادي عشر 

١‏ - قم بإنشاء جدول للادارات باسم )(٤۴A۸R۸1۷٧N٤[1(‏ يحتوي هذا الجدول على الأعمدة المطلوبة 
لتسجیل بیانات الإدارات » ثم قم بإنشاء القيد (إعK‏ إ۲٩١p۲1۳)‏ على عمود رقم الإدارة على مستوى الجدول 
وذلك آثاء انشاء الحدول ٩‏ 

کک وک فم بإانشاء جدول للموظفىين باسم (EMPLOYEE)‏ يحوي ف الأعمدة المطلوية لتسجيل بيانات 
الموظفىن « ثم فم بإانشاء القيد (UNIQUE)‏ لئ عمود سم الادارة وذلك گل مسنوی العمود نقسه › ثم 
قم بإنشاء القيد (إعK‏ إp۲1۳2۲)‏ على عمود رقم الموظف على مستوى الجدول آثناء إنشاء الجدول ٩‏ 

۲ - قم بإضافة القيد ۴٤1١ K۴۷(‏ ۴0۸) إلى جدول الموظفبن لربطه مح جدول الإدارات . 

4 - ضف فيد مناسب لجعل رواتب الموظفىن محصوره ين (5000 , 1000) . 


0 - قم بعرض آسماء الأعمدة والقيود المطبقة عليها . 


. EM P| 0Y۴ قم بعمرض أسماء القيود المطبقة على جدول الموظفين‎ - ٦ 


0ا - 


تقنية الحاسب الآلي ۱ حاب 


الارمجيات مقدمة قواعد بيانات أوراكل 


مفهوم فواعد البيانات 

اکل کرو دراس آنا ت 

أنواع آنظمة إدارة قواعد البيانات 
قواعد البيانات العلائقية 

التعامل مع قواعد البيانات العلائقية 
لغة الاستفسارات ا9۵ 

محرر بيئة ۴08 SQL*‏ 

أستلة الفصل الآول 


SEET 


استرجاع الحقول بآسماء مستعارة 

ا 

ا ارال اا 

No E 

استخدام عيارة (DISTICD‏ لمنع تڪرار السجلات 
و 

التعامل مع القيمة (N UL-(‏ 


E A 


المحتويات 


تقنية الحاسب الآلي ۱ حاب المحتويات 
البرمجيات مقدمة قواعد بيانات أوراكل 


الفصل الثالث :حصر و ترتبي البيانات 
الصيغة العامة لجملة الاستعلام 1 ٤1€‏ 
مقدمة 

WHERE hill ةلمnج‎ 

مكونات جملة الشرط 

متطلبات و إرشادات جملة الشرط 

ORDER BY بaترتلا جملة‎ 

متطلبات و إرشادات جملة الترتيب 

معاملات المقارنة المستخدمة 24 جملة الشرط 
E EL‏ الوط 
المعاملات المنطقية 

معامل النفي N01‏ 

A RSE 


الفصل الرابع : دوال الصف الواحد 


۰« با 


مقدمة 
الدوال الحرفية 

الدوال الرقمية 

دالة التاريخ 

دوال التحويل 

دllة‏ اlتحgyيJ TO CHAR‏ 
دالة التحویل 050۸1۴ 10 
دJlة‏ التحJıg NUMBER‏ 10 
أسئلة الفصل الرابع 


تقنية الحاسب الآلي ۱ حاب المحتويات 
البرمجيات مقدمة قواعد بيانات أوراكل 


الفصل الخامس: الدوال التجميعية لأكثر من صف 
مقدمة 

أنواع الدوال التجميعية 

التعامل مع دالة العد (C0٥١0 N1(‏ 

إنشاء مجموعات من البيانات باستخد|.) 8¥ (GROUP‏ 
ملاحظات على استخدام الدوال التجميعية 


اة ١‏ لفصل الخامس 


الفصل السادس: عرض البيانات من آڪثر من جدول 
مقدمة 

تعريف الربط 

آنواع الربط 

الربط بالتساوي 

الربط بعدم البتساوي 

الربط الخارجي 

اترا الوا فر اتون 

الربط بين آڪٿر من جدولين 

ا ادي 


الفصل السابع : الاستعلامات الفرعية 

مقدمة 

آنواع الاستعلامات 

متطلبات و إرشادات الاستعلام الفرعي 

أنواع معاملات المقارنة المستخدمة مع الاستعلام الفرعي 
أماكن كتابة الاستعلامات الفرعية داخل جملة 1 ©٤1٤٣‏ 
الا ااك القره عاد الضف 

الاستعلامات الفرعية متعددة الصفوف 


تقنية الحاسب الآلي ۱ حاب المحتويات 
البرمجيات مقدمة قواعد بيانات أوراكل 


أستلة الفصل السابع 


الفصل الثامن : الاستعلام الفرعي متعدد الأعمدة 

مقدمة 

a EE NOL N O N 

نتيجة الاستعلام الرئيس عندما يرجع الاستعلام الفرعي بالقيمة N11‏ 
استخدام الاستعلام الفرعي 2 جlnة F۴ORM‏ 


AN AAI 


الفصل التاسع : التعامل مع البيانات 

مقدمة 

إضافة سجلات إلى جدول 

الا العامة لا شاف معخلات 

القواعد التي يجب التقيد بها عند الإضافة 
إضافة القيم 01 إلى عمود 

إضافة قيم خاصة داخل الأعمدة 

إضافة سجلات باستخدام التغيرات البديلة 
إضافة سجلات عن طريق نسخها من جدول آخر 
الو 5 و 
الصيغ العامة لتعديل بيانات السجلات 

القواعد التي يجب التقيد بها عن التعديل 
التعديل ج آڪٽر من عمود 

حدذف السجلات من الجدول 

القواعد التي يحب التقيد بها عند الحذف 
عمليات قواعد البيانات Database 1r a^S4°†1018‏ 
حفظ البيانات 

أسئلة الفصل التاسع 


تقنية الحاسب الآلي ۱ حاب المحتويات 
البرمجيات مقدمة قواعد بيانات أوراكل 


ال او ا ا 

مقدمة 

آنواع البيانات 

EE e 
إنشاء الجداول‎ 

E E 

إانشاء الجداول باستخدام الأستعلامات الفرعية 
التعديل ج الجدول 

إلغاء الجدول 

تغيير آسم الجدول 

آنواع الجداول ے بيئّة آوراڪل 

اال ار 


الفصل الحادي عشر : القيود على الجداول 


«« 


و 
أنواع القيود 

انا 2 الفوة 

PRIMARY KÊY القيید‎ 
UNIQUE KEY دıتڙll‎ 
FOREIGN KEY دıall‎ 

CHECK ديقلı‎ 

إضافة فيود على الجدول 

إزالة القيود من الجداول 

استعراض القيود المطبقة على جدول معين 
أستلة الفصل الحادي عشر 


المالي المقدم من شركة بي آيه إي سيستمز (العمليات) المحدودة 


GOTEVOT apprec1ates the financial support provided by BAE SYSTEMS 


BAE SYSTEMS 


